<script>
(function(d, debug){
var js, id = 'facebook-jssdk', ref = d.getElementsByTagName('script')[0];
if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/ar_AR/all.js#xfbml=1&appId=356233997758493";
ref.parentNode.insertBefore(js, ref);
}(document, /*debug*/ false));
</script>
这就是我初始化facebook sdk的方法,问题是当我第一次加载页面时,window.fbAsyncInit中的任何代码都没有加载,但是当我刷新页面时它工作正常。
你知道问题可能是什么吗?
答案 0 :(得分:1)
我通过将我的Facebook的SDK片段移到索引文件的最底部,就在结束</body>
标记之前解决了这个问题。
...
<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/sdk.js";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
</script>
</body>
答案 1 :(得分:0)
您可以使用 window.onload 来解决此问题,以便在页面加载时包装您想要执行的任何功能。可能不漂亮,但它确实有效。
<script>
//Executes on page load
window.onload = function(){
window.fbAsyncInit = function(){
//Init stuff
};
FB.getLoginStatus(function(response) {
//...
};
};
// Load the SDK asynchronously
(function(d){
//stuff
}(document));
</script>