不确定这是否可行,但是....
第 1 步:在您的 facebook 初始化代码中,为 auth.authResponseChange 注册一个事件侦听器,当您检测到该 response.status==='not_authorized' 时,您将一些“全局”js 变量设置为标志
第 2 步:在您的按钮的单击处理程序中,在注销调用之后......使用等待直到设置了“全局”变量的 while 循环,然后调用 FB.login
<script>
// Create a "global" flag which will be set when the user has logged out
FB_LOGGED_OUT_FLAG=0;
window.fbAsyncInit = function() {
FB.init({
appId : 'YOUR_APP_ID', // App ID
channelUrl : '//WWW.YOUR_DOMAIN.COM/channel.html', // Channel File
status : true, // check login status
cookie : true, // enable cookies to allow the server to access the session
xfbml : true // parse XFBML
});
FB.Event.subscribe('auth.authResponseChange', function(response) {
if (response.status === 'connected') { FB_LOGGED_OUT_FLAG=0
} else if (response.status === 'not_authorized') {FB_LOGGED_OUT_FLAG=0
} else { //SET YOUR GLOBAL FLAG
FB_LOGGED_OUT_FLAG =1;
}
});
};
var MY_SWITCH_USER_BUTTON_HANDLER = function(){
FB.logout();
while(!FB_USER_LOGGED_OUT_FLAG) {}
FB.login()
}
// Load the SDK asynchronously
(function(d){
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/en_US/all.js";
ref.parentNode.insertBefore(js, ref);
}(document));
}
</script>
不确定这是否会在 while 循环执行时锁定用户的机器。我认为不会,它只是在您页面的线程内执行