webview和原生应用交互

webview和原生应用JS交互

定义关联的对象

public class Bridge2Js {
   private Activity activity;
    public Bridge2Js(Activity activity){
        this.activity = activity;
    }
    //4.2之后需要加注解否则报错
  @JavascriptInterface
   public void startPage(int pageSign, String json){
        activity....
   }

   @JavaInterface
   public void clickOnAndroid(){

   }
}

设置关联类

WebSettings mWebSettings = mProgressWebView.getSettings();
//允许js交互
mProgressWebView.addJavascriptInterface(new Bridge2Js(this), "bridge");

在JS代码中调用Android代码

//button
<input type="button"  value="click me"  onclick="window.bridge.startPage(0,'asd')"/>

//标准html
<!DOCTYPE html>   
<html>
    <script language="javascript">
        /在Android代码中可以调用下面js函数/
        function wave() {
            alert("1");
            document.getElementById("droid").src="android_waving.png";
            alert("2");
        }
    </script>
    <body>
        <!-- 在这里调用Andriod函数 -->
        <a onClick="window.bridge.clickOnAndroid()">Click me!</a>
    </body>
</html> 

在Android中调用JS代码

webview.loadUrl("javascript:wave()");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值