WebView中的JavaScript为什么不执行

 我来答
匿名用户
2015-06-17
展开全部
webview.setWebViewClient(new MyWebViewClient(this, browser)); MyWebViewClientonPageFinished注入javascript代码 public class MyWebViewClient extends WebViewClient { private Context con; public PTCWebViewClient(Context con, final WebView web){ this.con = con; } @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon); } @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); view.loadUrl("javascript:(function(){document.getElementById('snapNSendBtn').onclick=function(){window.ltamtc.toSnapNSend();}})()"); } } 每webView加载完页面且页面IDmySourceButton元素元素点击事件修改用户自定义暴露给javascript调用toMyPage()事件旦点击界面跳转或者做任何想做事情
受司大人
推荐于2018-05-06 · 知道合伙人影视综艺行家
受司大人
知道合伙人影视综艺行家
采纳数:20262 获赞数:171846
毕业于浙江广厦,有一定的电脑专业基础和两年工作经验,读过相关书籍多本

向TA提问 私信TA
展开全部
浏览器未开启javascript
使用的js代码有问题,webview不兼容该代码。

1) 第一个坎:WebSettings

WebSettings webSettings = mWebView.getSettings();
webSettings.setJavaScriptEnabled(true);

2) 第二个坎: 有物
在运行脚本前,要有document对象,至少得load一个空白页

webView.loadData(“”,"text/html","UTF-8");

3)第三个坎: 异步
如果这么写是没戏的,因为第一个还没执行完呢

webView.loadData(“”,"text/html","UTF-8");
webView.loadUrl("javascript:alert('hello')");

解决这个问题。可以1)从界面按钮调用 2)延时调用。 3)在onPageFinished中调用

mWebView.setWebViewClient(new MyWebViewClient());
private class MyWebViewClient extends WebViewClient {
@Override
public void onPageFinished(WebView webView, String url) {
webView.loadUrl("javascript:"+script);
}
}

4)第四个坎:console/alert

以上三点完成后,js已经可以执行,可是为什么看不到console.log和alert呢?因为这2个要额外实现

mWebView.setWebChromeClient(new MyWebChromeClient()); //optional, for show console and alert
private class MyWebChromeClient extends WebChromeClient {
@Override
public boolean onConsoleMessage(ConsoleMessage cm) {
Log.d("test", cm.message() + " -- From line "
+ cm.lineNumber() + " of "
+ cm.sourceId() );
return true;
}

@Override
public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
Toast.makeText(mContext, message, Toast.LENGTH_SHORT).show();
return true;
}
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式