javascript - Android 的 webview 中怎么监听 url 的 hash 变化
问题描述
场景Android 的 webview 中加载一个 SPA (单页面应用)网站
过程我通过 shouldoverrideurl 方法来监听 Webview 的 URL,对 URL 进行某些预处理
但是,SPA 中大部分是 hash 值变化,因此这个方法就监听不到变化
举例从 a.html#/home 跳转到 a.html#/other
问题请问有什么办法监听 hash 值的变化吗?
问题解答
回答1:只能通过 HTML5 新增加的 window.onhashchange() API。shouldoverrideurl 应该监听不到吧。
如果你不想修改 js 代码,可以在 java 中注入:
定义一个处理 js 的类:
private class MyJSI { public void doStuff() {// 你的逻辑 }}
注入到 webview 中:
webView.addJavascriptInterface(new MyJSI(), 'myjsi');
监听 onhashchange 事件:
webview.setWebViewClient(new WebViewClient() { public void onPageFinished(WebView view, String url) {view.loadUrl('javascript:window.onhashchange = function() { myjsi.doStuff(); };'); }});
相关文章:
1. javascript - swiper插件loop模式下的BUG?2. 运维 - java tomcat多个小项目共存问题3. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””4. dockerfile - 为什么docker容器启动不了?5. javascript - sublime快键键问题6. javascript - 想做一个canvas的触摸画板,但屏幕会在画的时候滚来滚去,如何阻止?7. javascript - webpack构建工具重构代码的流程是怎么样的?8. mysql连表排序9. javascript - 请教下关于emoji在WEB输出的问题。10. javascript - 图片请求失败怎么去掉左上角的小图标?

网公网安备