0

FacebookのようなAPIに問題があります。次のコードでいいねボタンを作成しています。

<fb:like href="http://www.nettunes.co.za/artist_profile.php?ref=fb&amp;amp;artist_id=<?PHP echo $row->artist_id;?>&amp;amp;show=albums&amp;amp;sub_section=song&amp;amp;id=<?PHP echo $row->song_id;?>" layout="box_count" show_faces="false" width="50" font="arial" title="<?PHP echo ucfirst($row->song_name);?> by <?PHP echo $row->artist_name;?> on www.nettunes.co.za"></fb:like>

次に、イベントをリッスンし、javascript 関数を呼び出します。この ajax は、このアーティストのすべてのいいねを追跡するためにローカル データベースにいいねを挿入する PHP の一部を実行します。このコードを使用して:

var e = document.createElement('script');
e.type = 'text/javascript';
e.src = document.location.protocol +
  '//connect.facebook.net/en_US/all.js';
e.async = true;
document.getElementById('fb-root').appendChild(e);
    FB.Event.subscribe('edge.create', function(response) {
        var song_id = response.toString().split("&amp;id=");
        likeSong(song_id[1]);
    });

問題は、常にこの likeSong 関数を呼び出してデータベースに like を追加するとは限らないことです。

誰かが以前に同様の問題を抱えていましたか? または、これを行うより良い方法を知っていますか?

本当にありがとう

気をつけて、クレガン

4

1 に答える 1

2

Facebookライブラリの準備が完全に整うのを待って、応答を確認する必要があります。fbAsyncInitこれは、ライブラリが非同期で読み込まれるとFacebookによって呼び出されるメソッドを使用して実行できます。

<div id="fb-root"></div>
<script type="text/javascript" charset="utf-8">
window.fbAsyncInit = function() {
    FB.init({appId:"1234567890", status:true, cookie:true, xfbml:true, session:null});
    FB.Event.subscribe('edge.create', function(response) {
        if (response)
        {
            var song_id = response.toString().split("&amp;id=");
            likeSong(song_id[1]);
        }
    });
}

(function() {
var e = document.createElement("script");
e.src = document.location.protocol + "//connect.facebook.net/en_US/all.js";
e.async = true;
document.getElementById("fb-root").appendChild(e);
}());
</script>

また、Facebookライブラリが読み込まれる前に、likeSongが定義されている場所が初期化されていることを確認し、そのイベントリスナーを追加する必要があります。

于 2010-11-26T08:53:23.437 に答える