Update am 04. Januar 2012
Es scheint, dass Sie nicht einfach FB-abhängige Methoden (zum Beispiel FB.getAuthResponse()) direkt nach FB.init()wie zuvor aufrufen können , da FB.init()dies jetzt asynchron zu sein scheint. Das Einschließen Ihres Codes in eine FB.getLoginStatus()Antwort scheint den Trick zu tun, zu erkennen, wann die API vollständig bereit ist:
window.fbAsyncInit = function() {
FB.init({
//...
});
FB.getLoginStatus(function(response){
runFbInitCriticalCode();
});
};
oder wenn Sie die fbEnsureInit()Implementierung von unten verwenden:
window.fbAsyncInit = function() {
FB.init({
//...
});
FB.getLoginStatus(function(response){
fbApiInit = true;
});
};
Ursprünglicher Beitrag:
Wenn Sie bei der Initialisierung des FB nur ein Skript ausführen möchten, können Sie eine Rückruffunktion einfügen fbAsyncInit:
window.fbAsyncInit = function() {
FB.init({
appId : '<?php echo $conf['fb']['appid']; ?>',
status : true, // check login status
cookie : true, // enable cookies to allow the server to access the session
xfbml : true // parse XFBML
});
FB.Canvas.setAutoResize();
runFbInitCriticalCode(); //function that contains FB init critical code
};
Wenn Sie FB.ensureInit exakt ersetzen möchten, müssen Sie selbst etwas schreiben, da es keinen offiziellen Ersatz gibt (großer Fehler imo). Folgendes benutze ich:
window.fbAsyncInit = function() {
FB.init({
appId : '<?php echo $conf['fb']['appid']; ?>',
status : true, // check login status
cookie : true, // enable cookies to allow the server to access the session
xfbml : true // parse XFBML
});
FB.Canvas.setAutoResize();
fbApiInit = true; //init flag
};
function fbEnsureInit(callback) {
if(!window.fbApiInit) {
setTimeout(function() {fbEnsureInit(callback);}, 50);
} else {
if(callback) {
callback();
}
}
}
Verwendung:
fbEnsureInit(function() {
console.log("this will be run once FB is initialized");
});