使用webview Android和js进行通信

Android调用js的方法

webView.evaluateJavascript("javascript:aaa(1)") {
        value -> Log.i("webView", value ?: "null")
 }

aaa是js端定义的方法,1为传的参数,value是方法返回的值

js调用Android的方法

1.定义一个类,里面定义一个带 @JavascriptInterface注解的方法,直接return js可以接收到返回值

// 继承自Object类
class AndroidtoJs : Any() {
    // 定义JS需要调用的方法
    // 被JS调用的方法必须加入@JavascriptInterface注解
    @JavascriptInterface
    fun hello(msg: String?):String {
        Log.i("AndroidtoJs", "JS调用了Android的hello方法")
        return "kaylee"
    }
}

2.在使用webview的地方将Android对象映射到js的test对象

val mWebSettings = webView.settings
mWebSettings.javaScriptEnabled = true//是否允许JavaScript脚本运行,默认为false
webView.addJavascriptInterface(AndroidtoJs(), "test") //AndroidtoJS类对象映射到js的test对象

3.js的代码

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title>Carson</title>  
      <script>
         function callAndroid(){
        // 由于对象映射,所以调用test对象等于调用Android映射的对象
            test.hello("js调用了android中的hello方法");
         }
      </script>
   </head>
   <body>
      //点击按钮则调用callAndroid函数
      <button type="button" id="button1" onclick="callAndroid()"></button>
   </body>
</html>

参考:android webview与网页通信的几种方式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值