以下是Facebook建議如何將JS SDK添加到您的源代碼。Facebook JS SDK:正確的方式來初始化SDK
window.fbAsyncInit = function() {
FB.init({
appId : '{your-app-id}',
status : true,
xfbml : true
});
};
(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";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
如果我理解正確的話,代碼的第二部分,創建DOM中的<script></script>
節點並設置源//connect.facebook.net/en_US/all.js
爲什麼window.fbAsyncInit
功能之前來,而不是之後?瀏覽器是否會在實際加載到SDK實際加載的代碼的第二部分之前嘗試運行它?只有在FB.init()
被調用後纔有可能將all.js加載到DOM中,從而產生錯誤?