广泛支持
Facebook Messenger Extension close 方法是最兼容的方法。在移动设备上它会关闭 webview,在桌面上它将关闭选项卡(webviews 在桌面信使的新选项卡中打开)。
首先,将您的域列入白名单,以便能够使用 Messenger Extensions,为您的应用使用访问令牌。使用您为机器人生成的 page_access_token。
curl -X POST -H "Content-Type: application/json" -d '{
"whitelisted_domains":[
"https://petersfancyapparel.com"
]
}' "https://graph.facebook.com/v2.6/me/messenger_profile?access_token=PAGE_ACCESS_TOKEN"
将 Messenger SDK 与视频一起加载到您的 webview 页面上
<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.com/en_US/messenger.Extensions.js";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'Messenger'));
</script>
然后给video元素添加一个事件监听器来调用关闭浏览器函数
<video src="video.ogv" id="myVideo">
video not supported
</video>
<script type='text/javascript'>
document.getElementById('myVideo').addEventListener('ended',myHandler,false);
function myHandler(e) {
MessengerExtensions.requestCloseBrowser(function success() {
}, function error(err) {
});
}
</script>
仅限 iOS
快速而肮脏的 ios 唯一方法是https://www.messenger.com/closeWindow/?image_url=IMAGE_URL&display_text=DISPLAY_TEXT
在窗口关闭之前进行重定向,短暂显示指定的图像和文本。这方面的文档
为此你会做
window.replace('https://www.messenger.com/closeWindow/?image_url=IMAGE_URL&display_text=DISPLAY_TEXT')