Есть ли способ сделать кнопку Facebook Share, которая будет размещать произвольный текст на стене или в ленте новостей?
Ответы:
Мы используем что-то вроде этого [использовать в одну строку]:
<a title="send to Facebook"
href="http://www.facebook.com/sharer.php?s=100&p[title]=YOUR_TITLE&p[summary]=YOUR_SUMMARY&p[url]=YOUR_URL&p[images][0]=YOUR_IMAGE_TO_SHARE_OBJECT"
target="_blank">
<span>
<img width="14" height="14" src="'icons/fb.gif" alt="Facebook" /> Facebook
</span>
</a>
<a class="facebook" target="_blank" onclick="return !window.open(this.href, 'Facebook', 'width=640,height=300')" href="http://www.facebook.com/sharer/sharer.php?u=YOUR_URL">Facebook</a>
и т. д.
Чтобы предоставить пользовательские параметры для публикации в facebook, лучше указать только ссылку, и facebook автоматически получит заголовок + описание + изображение со страницы, которой вы делитесь. Чтобы «помочь» API Facebook найти эти вещи, вы можете поместить следующие вещи в заголовок страницы, которой вы делитесь:
<meta property="og:title" content="title" />
<meta property="og:description" content="description" />
<meta property="og:image" content="thumbnail_image" />
Если страница не находится под вашим контролем, используйте то, что AllisonC поделился выше.
Используйте свою собственную кнопку / ссылку / текст, а затем вы можете использовать всплывающее окно модального вида следующим образом:
<script type= 'text/javascript'>
$('#twitterbtn-link,#facebookbtn-link').click(function(event) {
var width = 575,
height = 400,
left = ($(window).width() - width) / 2,
top = ($(window).height() - height) / 2,
url = this.href,
opts = 'status=1' +
',width=' + width +
',height=' + height +
',top=' + top +
',left=' + left;
window.open(url, 'twitter', opts);
return false;
});
</script>
где twitterbtn-link и facebookbtn-link - оба идентификатора привязки.
if( window.open(.....) ) event.preventDefault();
а не просто `return false; ˙! - таким образом он предотвращает только поведение по умолчанию (ссылка открыта) при открытии окна - обеспечивает откат, когда его не было ...
используйте эту функцию, полученную из ссылки, предоставленной IJas
function openFbPopUp() {
var fburl = '';
var fbimgurl = 'http://';
var fbtitle = 'Your title';
var fbsummary = "your description";
var sharerURL = "http://www.facebook.com/sharer/sharer.php?s=100&p[url]=" + encodeURI(fburl) + "&p[images][0]=" + encodeURI(fbimgurl) + "&p[title]=" + encodeURI(fbtitle) + "&p[summary]=" + encodeURI(fbsummary);
window.open(
sharerURL,
'facebook-share-dialog',
'width=626,height=436');
return false;
}
Или вы также можете использовать последнюю функцию FB.ui, если используете FB JavaScript SDK для более контролируемой функции обратного вызова.
см .: FB.ui
function openFbPopUp() {
FB.ui(
{
method: 'feed',
name: 'Facebook Dialogs',
link: 'https://developers.facebook.com/docs/dialogs/',
picture: 'http://fbrell.com/f8.jpg',
caption: 'Reference Documentation',
description: 'Dialogs provide a simple, consistent interface for applications to interface with users.'
},
function(response) {
if (response && response.post_id) {
alert('Post was published.');
} else {
alert('Post was not published.');
}
}
);
}
У вас есть несколько вариантов:
Вы можете настроить диалоговое окно общего доступа Facebook, используя асинхронный JavaScript SDK, предоставляемый Facebook, и задав значения его параметров.
Взгляните на следующий код:
<script type="text/javascript">
$(document).ready(function(){
$('#share_button').click(function(e){
e.preventDefault();
FB.ui(
{
method: 'feed',
name: 'This is the content of the "name" field.',
link: 'URL which you would like to share ',
picture: ‘URL of the image which is going to appear as thumbnail image in share dialogbox’,
caption: 'Caption like which appear as title of the dialog box',
description: 'Small description of the post',
message: ''
}
);
});
});
</script>
Перед копированием и вставкой приведенного ниже кода необходимо сначала инициализировать SDK и настроить библиотеку jQuery. Пожалуйста, нажмите здесь, чтобы узнать шаг за шагом, как установить информацию о том же.
Это текущее решение (декабрь 2014 г.), которое работает достаточно хорошо. Это особенности
<a onclick="return !window.open(this.href, 'Share on Facebook', 'width=640, height=536')" href="https://www.facebook.com/sharer/sharer.php?u=href=$url&display=popup&ref=plugin" target="_window"><img src='/_img/icons/facebook.png' /></a>
$ url var должен быть определен как URL для совместного использования.
Это простой диалог, который предлагает Facebook. Читайте здесь более подробно ссылку
вы можете объединить идею AllisonC с window.open
функцией:
http://www.w3schools.com/jsref/met_win_open.asp
function openWin(url) {
myWindow = window.open(url, '', 'width=800,height=400');
myWindow.focus();
}
И затем для каждой ссылки вы вызываете функцию openWin с правильным URL-адресом социальной сети.
Попробуйте этот сайт http://www.sharelinkgenerator.com/ . Надеюсь это поможет.