WebView中JavaScript如何监听按Home键退出事件?

WebView中JavaScript如何监听按Home键退出事件?

在微信里测试了下,当iPhone按住 home键退出微信再打开。

阅读 9.9k
3 个回答

不知道WebView支持下方哪一个

  • window之上的blur事件
  • document之上的visibilitychange事件

visibilitychange事件示例和shim可见DEMO

新手上路,请多包涵

js是做不到的。可以java中做监听,通过WebView调页面中js函数达到目的。

目前来说浏览器里的js是做不到的,不过你可以让native来帮助你实现这个功能。就算如此,也仅仅是实现类似的应用进入后台监听而已。

第一步,在你的applicationDidEnterBackground中发送一个NSNotification

第二步,在你的WebViewController中接收这个NSNotification(这里我觉得通过NSNotificationCenter来做这个事最合适,你想用其他方式也行)

第三步,

// 为了方便阅读,写成这样
[webView stringByEvaluatingJavaScriptString:@"
                        var pauseEvent = new Event('pause');
                        document.dispatchEvent(pauseEvent);
"];

最后一步,现在,你可以在你的js文件中像这样来监听应用的进入后台事件:

document.addEventListener('pause', function () {
    console.log('app just entered background.');
});

最后打个广告,我们做了一个让web app像native app来运行的手机浏览器(当然也包括了你的这个需求,监听应用的进入后台事件),支持各种 PhoneGap API,支持直接调起 native 的微信分享(再也不用在网页上画个箭头指向右上角了)。

下载地址: http://lydiabox.com
API 文档:http://wiki.lydiabox.com
开发者中心: http://developer.lydiabox.com

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题