android - 关于一个简单的webview中直接执行javascript函数的问题
问题描述
坦白讲应该是不难的,但本人不会js 所以开发起来有点难以下手 , 百度了很多的demo看了之后自己写完还是有问题 不知道什么情况 特来请教大家
我自己是在android平台写的
登陆地址: http://101.226.249.86:8080/jservice/#/SignIn (将这个地址用webview显示出来)
一.交互方式:
客户端网页中发起一个自定义url的请求,浏览器可以拦截到对应的请求;这一过程
相当于网页给Webview 发起了一个事件通知,其中自定义URL请求格式为:
ccn-webkit-bridge://xxx?functionName=xx
其中functionName参数是回调javascript函数的名字
接着webview中直接执行javascript函数,获取到对应的参数;
执行相关的native操作.
二.
客户端登录结束, 待服务器返回登录结果之后,执行如下的javascript代码
/**
该函数供 webkit 回调,返回 login 结果给 webkit
@return 注册 login 结果的 json 对象的字符串格式
**/
xxx() {
null
}
以上是人家给我的东西, 剩下都靠自己写
以下第一张图是登录页面,是一个webview, ,第二张是点击登录后的样子
附上自己的一部分代码 希望对答者有帮助,谢谢.
webView.loadUrl("http://101.226.249.86:8080/jservice/#/SignIn");
//启用支持javascript 加上这句话才能使用javascript方法
WebSettings settings = webView.getSettings();
settings.setJavaScriptEnabled(true);
//优先使用缓存
settings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
webView.addJavascriptInterface(new MyJavaScriptInterface(), "getResult");
webView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
//返回值是true的时候控制去WebView打开,为false调用系统浏览器或第三方浏览器
view.loadUrl(url);
return false;
}
});
//window.location.href = "ccn-webkit-bridge://did-login?functionName=getResult";
//webView.addJavascriptInterface(new Object(), "getResult");
public boolean shouldOverrideUrlLoading(...) {
view.loadUrl(url);//
return true;
}
这个方法你调用了
view.loadUrl(url);
,所以WebView就去加载那个连接
而那个链接是无法正常显示的,因此出现下图的异常按照你的说法,应该是 识别到这个 URL 后,原生代码去执行相关的操作
最终将 原生代码的结果反馈给 WebView
所以,我感觉正确的流程是:
public boolean shouldOverrideUrlLoading(...) {
if({是调用native方法的连接}) {
// 执行native逻辑
// 你当前的逻辑是, 调用js方法,拿参数,去登录,取结果,再给webview
return true; // 不调用`loadUrl`,无刷新webview
} else {
view.loadUrl(url);// 比如打开了一个新的其他的链接
return true;
}
}
希望能解决的你的问题
这篇关于android - 关于一个简单的webview中直接执行javascript函数的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!