文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android使用webview进行android与js互相调用(带源码)

2022-06-06 14:07

关注

一.添加权限
 
二.js调用android代码

1.需要写一个java对js方法的映射

public class AndroidToJS {
    // 定义JS需要调用的方法
    // 被JS调用的方法必须加入@JavascriptInterface注解
    @JavascriptInterface
    public void callAndroid(String msg){
        Log.e("l2","JS调用了Android的callAndroid(),msg : " + msg);
    }
}

2.activitiy类,webview设置,把接口方法添加进webview对象等

  WebSettings settings = webView.getSettings();
        //允许WebView使用JS
        settings.setJavaScriptEnabled(true);
        //支持通过JS打开新窗口(允许JS弹窗)
        settings.setJavaScriptCanOpenWindowsAutomatically(true);
        //约定好对象在前端的调用名字
        webView.addJavascriptInterface(new AndroidToJS(),"android");

3.前端代码


//Android原生调用JS方法 function callJS(msg){ alert(123) android.callAndroid('123'); } //JS调用Android原生方法 function callAndroid(){ android.callAndroid("123"); }

核心代码是

 webView.addJavascriptInterface(new AndroidToJS(),"android");
android.callAndroid("123");

在点击了之后,其实就是向Android那传了123. logcat中打印出了123
在这里插入图片描述

三、Android向js端传值(也是android调用js)

上面的html代码有个callJS。所以在Android那里设置回调,在onPageFinished回调之后写可以避免js调用失效。

webView.setWebViewClient(new WebViewClient(){
            @Override
            public void onPageFinished(WebView view, String url) {
                //页面跳转结束后被回调
                btnAndroidCallJS.setOnClickListener(new View.OnClickListener() {
                    @RequiresApi(api = Build.VERSION_CODES.KITKAT)
                    @Override
                    public void onClick(View v) {
//                        webView.loadUrl("http://10.0.2.2:8000/test");
                        webView.loadUrl("javascript:callJS("+123+")");
//                        webView.evaluateJavascript("javascript:callJS("+123+")", new ValueCallback() {
//                            @Override
//                            public void onReceiveValue(String s) {
//                                Log.e("zw",s); //这里s是“Android调用了JS的callJS()”
//                            }
//                        });
                    }
                });
            }
            @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
            @Override //方法二
            public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
                Uri uri = request.getUrl();
                if("js".equals(uri.getScheme())){
                    if("webview".equals(uri.getAuthority())){
                        String msg=uri.getQueryParameter("arg2");
                        Log.e("l2", uri.getScheme() + " , " + uri.getAuthority() + " , "+msg);
//                        Toast.makeText(getApplicationContext(),"heihei",Toast.LENGTH_SHORT).show();
                        return true;
                    }
                }
                return super.shouldOverrideUrlLoading(view, request);
            }
        });

核心是下面的,这样就可以传值到前端了。兼容Android4.4以下版本
前端js返回值,并不是通过return, webView.loadUrl并没有实现回调接口,js返回值其实是通过js调用android方法来实现,所以这是为什么我先说js调用Android了。

 webView.loadUrl("javascript:callJS("+123+")");

如果你是Android4.4,即api版本19以上,不考虑之下得兼容。可以使用下面得方式。不仅效率好,而且api原生设计有回调接收前端js返回值

 webView.evaluateJavascript("javascript:callJS("+123+")", new ValueCallback() {
//                            @Override
//                            public void onReceiveValue(String s) {
//                                Log.e("zw",s); //这里s是“Android调用了JS的callJS()”
//                            }
//                        });
四、 布局文件

    

注意的是,如果你用android模拟器和你的本地服务器做调试请用10.0.2.2,因为本地服务器的127.0.0.1是主机电脑,而模拟器的127.0.0.1是自己手机,Android提供了10.0.2.2这个特殊地址映射了主机的127.0.0.1

webView.loadUrl("http://10.0.2.2:8000/test");

以上是我的总结,推荐文章

https://www.jianshu.com/p/757a4a337b15

https://www.jianshu.com/p/5cc2eae14e07

项目源码
https://pan.baidu.com/s/1gUOhwFOofulP7sq9JyVD3Q

4sum


作者:练气期小修士


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯