Оновлення 04 січня 2012 року
Схоже, ви не можете просто викликати залежні від FB методи (наприклад FB.getAuthResponse()
) відразу після, FB.init()
як раніше, як це FB.init()
здається асинхронним зараз. Якщо ввімкнути ваш код у FB.getLoginStatus()
відповідь, схоже, виправдаєтесь, коли API повністю готовий:
window.fbAsyncInit = function() {
FB.init({
//...
});
FB.getLoginStatus(function(response){
runFbInitCriticalCode();
});
};
або якщо використовується fbEnsureInit()
реалізація знизу:
window.fbAsyncInit = function() {
FB.init({
//...
});
FB.getLoginStatus(function(response){
fbApiInit = true;
});
};
Оригінальна публікація:
Якщо ви хочете просто запустити якийсь сценарій при ініціалізації FB, ви можете помістити функцію зворотного дзвінка всередину 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
};
Якщо ви хочете точної заміни FB.ensureInit, вам доведеться щось написати самостійно, оскільки офіційної заміни немає (велика помилка imo). Ось що я використовую:
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();
}
}
}
Використання:
fbEnsureInit(function() {
console.log("this will be run once FB is initialized");
});