iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android使用webview进行android与js互相调用(带源码)
  • 280
分享到

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

调用webviewjs源码Android 2022-06-06 14:06:53 280人浏览 独家记忆
摘要

一.添加权限 二.js调用Android代码 1.需要写一个java对js方法的映射 public class AndroidToJS {

一.添加权限
 
二.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


作者:练气期小修士


--结束END--

本文标题: Android使用webview进行android与js互相调用(带源码)

本文链接: https://www.lsjlt.com/news/29675.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作