私はうまくいくと思われるがうまくいかないこのコードを持っています。これがとにかくあなたを助けてくれるなら、それは素晴らしいことです。
<script src='http://connect.facebook.net/en_US/all.js'></script>
<p><a onclick='postToFeed(); return false;'><img src="images/fb.png" /></a></p>
<p id='msg'></p>
<script>
FB.init({appId: "338334836292077", status: true, cookie:
true});
function postToFeed() {
// calling the API ...
var obj = {
method: 'feed',
redirect_uri:'https://www.facebook.com/cryswashington?fref=ts',
link:'https://developers.facebook.com/docs/reference/dialogs/',
picture: 'http://fbrell.com/f8.jpg',
name: 'Facebook Dialogs',
caption: 'Reference Documentation',
description: 'Using Dialogs to interact with users.'
};
function callback(response) {
document.getElementById('msg').innerHTML = "Post ID: " + response['post_id'];
}
FB.ui(obj, callback);
}
</script>
私は自分のウェブサイトにfacebookの共有ボタンを追加したいのですが、それは壁に自分のウェブサイトのコンテンツを投稿するだけです。それを共有したい人。
私はたくさん研究しましたが、何も得られませんでした。これを手伝ってください。
前もって感謝します。
そのようなコードはすべて必要ありません。必要なのは次の行だけです。
<a href="https://www.facebook.com/sharer/sharer.php?u=example.org" target="_blank">
Share on Facebook
</a>
ドキュメントは https://developers.facebook.com/docs/reference/plugins/share-links/ にあります。
あなたはfacebookによって提供される非同期Javascript SDKを使うことによってこれをすることができます
次のコードを見てください
FB Javascript SDKの初期化
<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
FB.init({appId: 'YOUR APP ID', status: true, cookie: true,
xfbml: true});
};
(function() {
var e = document.createElement('script'); e.async = true;
e.src = document.location.protocol +
'//connect.facebook.net/en_US/all.js';
document.getElementById('fb-root').appendChild(e);
}());
</script>
注:あなたのアプリIDをあなたのFacebookのAppIdに置き換えることを忘れないでください。 FacebookのAppIdがなく、作成方法がわからない場合は、 これを確認してください
JQueryライブラリを追加します。Googleライブラリを優先します
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js" type="text/javascript"></script>
[共有の追加]ダイアログボックス(このダイアログボックスは、パラメータを設定してカスタマイズできます
<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: 'http://www.groupstudy.in/articlePost.php?id=A_111213073144',
picture: 'http://www.groupstudy.in/img/logo3.jpeg',
caption: 'Top 3 reasons why you should care about your finance',
description: "What happens when you don't take care of your finances? Just look at our country -- you spend irresponsibly, get in debt up to your eyeballs, and stress about how you're going to make ends meet. The difference is that you don't have a glut of taxpayers…",
message: ""
});
});
});
</script>
最後に画像ボタンを追加しました
<img src = "share_button.png" id = "share_button">
より詳細な情報についてお願いします ここをクリック
あなたは共有ボタンについてもっと読むことができます ここでFacebook開発者ウェブサイトで
作業中 JSFIDDLE
また、カスタムFacebookの[共有]ボタンJSFIDDLEを見てください。
開始<body>
タグの直後にFacebook JavaScript SDKコードを含める
<div id="fb-root"></div>
<script>(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/all.js#xfbml=1";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>
Facebookの[共有]ボタンを表示する場所は、コードの下に配置します。
<div class="fb-share-button" data-href="https://developers.facebook.com/docs/plugins/" data-width="200" data-type="button_count"></div>
動作確認 JSFIDDLE
Facebookでの共有画像付きAPIなし、サブページへのディープリンクに#
を使う、トリック画像をpicture=
として共有することでした
変数mainUrl
はhttp://yoururl.com/
になります
var d1 = $('.targ .t1').text();
var d2 = $('.targ .t2').text();
var d3 = $('.targ .t3').text();
var d4 = $('.targ .t4').text();
var descript_ = d1 + ' ' + d2 + ' ' + d3 + ' ' + d4;
var descript = encodeURIComponent(descript_);
var imgUrl_ = 'path/to/mypic_'+id+'.jpg';
var imgUrl = mainUrl + encodeURIComponent(imgUrl_);
var shareLink = mainUrl + encodeURIComponent('mypage.html#' + id);
var fbShareLink = shareLink + '&picture=' + imgUrl + '&description=' + descript;
var twShareLink = 'text=' + descript + '&url=' + shareLink;
// facebook
$(".my-btn .facebook").off("tap click").on("tap click",function(){
var fbpopup = window.open("https://www.facebook.com/sharer/sharer.php?u=" + fbShareLink, "pop", "width=600, height=400, scrollbars=no");
return false;
});
// Twitter
$(".my-btn .Twitter").off("tap click").on("tap click",function(){
var twpopup = window.open("http://Twitter.com/intent/tweet?" + twShareLink , "pop", "width=600, height=400, scrollbars=no");
return false;
});
FB.ui関数にshare methodパラメータを指定してリンクを共有すると、共有ダイアログを起動できます。このダイアログは、JavaScript、iOS、およびAndroid用のFacebook SDKで、URLへの完全なリダイレクトを実行することによって使用できます。
あなたはこの呼び出しを引き起こすことができます:
FB.ui({
method: 'share',
href: 'https://developers.facebook.com/docs/', // Link to share
}, function(response){});
また、このURLのページのオープングラフメタタグを含めて、Facebookに共有されるストーリーをカスタマイズすることもできます。
Response.error_messageは、あなたのアプリを使用している誰かがあなたのアプリをFacebook Loginで認証した場合にのみ表示されます。
また、Javascript Facebook SDKを使用することで、通話とリンクを直接共有することもできます。
https://www.facebook.com/dialog/share&app_id=145634995501895&display=popup&href=https%3A%2F%2Fdevelopers.facebook.com%2Fdocs%2F&redirect_uri=https%3A%2F%2Fdevelopers.facebook.com%2Ftools%2Fexplorer
https://www.facebook.com/dialog/share&app_id={APP_ID}&display=popup&href={LINK_TO_SHARE}&redirect_uri={REDIRECT_AFTER_SHARE}
app_id =>あなたのアプリのユニークな識別子。 (必須。)
redirect_uri =>人がダイアログのボタンをクリックした後にリダイレクトするURL。 URLリダイレクトを使用する場合は必須です。
display =>ダイアログのレンダリング方法を決定します。
URLリダイレクトダイアログの実装を使用している場合、これはFacebook.com内に表示されるフルページ表示になります。この表示タイプはページと呼ばれます。 iOSまたはAndroidのSDKを使用してダイアログを起動している場合は、これが自動的に指定され、デバイスに適した表示タイプが選択されます。あなたがJavaScript用のFacebook SDKを使っているなら、これはあなたのアプリにログインした人々のためのモーダルiframeタイプかFacebook.comのゲームの中で使うとき非同期、そして他のみんなのためのポップアップウィンドウになります。必要に応じて、JavaScript用Facebook SDKを使用するときにポップアップまたはページタイプを強制することもできます。モバイルWebアプリは常にデフォルトでタッチディスプレイタイプになります。共有パラメータ
あなた自身の特定のサーバーや異なるページと画像ボタンのためにあなたはこのようなものを使うことができます(PHPのみ)
<a href="http://www.facebook.com/sharer/sharer.php?u=http://'.$_SERVER['SERVER_NAME'].'" target="_blank"><img src="http://i.stack.imgur.com/rffGp.png" /></a>
私はこれとスニペットを共有することはできませんが、あなたはアイデアを得るでしょう...