android - 关于一个简单的webview中直接执行javascript函数的问题

查看:79
本文介绍了android - 关于一个简单的webview中直接执行javascript函数的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

坦白讲应该是不难的,但本人不会js 所以开发起来有点难以下手 , 百度了很多的demo看了之后自己写完还是有问题 不知道什么情况 特来请教大家
我自己是在android平台写的
登陆地址: http://101.226.249.86:8080/jservice/#/SignIn (将这个地址用webview显示出来)
一.交互方式:

  1. 客户端网页中发起一个自定义url的请求,浏览器可以拦截到对应的请求;这一过程
    相当于网页给Webview 发起了一个事件通知,其中自定义URL请求格式为:

ccn-webkit-bridge://xxx?functionName=xx
其中functionName参数是回调javascript函数的名字

  1. 接着webview中直接执行javascript函数,获取到对应的参数;

  2. 执行相关的native操作.
    二.

客户端登录结束, 待服务器返回登录结果之后,执行如下的javascript代码

/**

  • 该函数供 webkit 回调,返回 login 结果给 webkit

  • @return 注册 login 结果的 json 对象的字符串格式
    **/

  1. xxx() {

  2. 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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆