安卓原生和 H5 交互

1.安卓调用 H5 的方法:

mWebView.loadUrl("javascript:webViewNotice(" + "'" + messageNum + "'" + ")");

其中,webViewNotice是方法名,messageNum是原生传给 H5 的参数。安全起见,mWebView 最好判空一下。

2.H5调用安卓原生的方法:

WebSettings settings = webView.getSettings();
settings.setJavaScriptEnabled(true); // 开启Javascript支持
settings.setUseWideViewPort(false);// 将图片调整到适合webview的大小
settings.setSupportZoom(true);// 支持缩放
settings.setLoadsImagesAutomatically(true); // 设置可以自动加载图片
settings.setCacheMode(WebSettings.LOAD_DEFAULT); // 关闭webview中缓存
settings.setDomStorageEnabled(true); // 设置DOM缓存
webView.setWebChromeClient(new MyWebChromeClient());
webView.addJavascriptInterface(new JsObject(context), "javaToJs");

这其中 settings.setJavaScriptEnabled(true)必须要有,允许在 WebView 中使用 js;
MyWebChromeClient 是 WebChromeClient 的子类;
javaToJs是原生定义给 H5 使用的对象,JsObject 代码如下:

public class JsObject {

    public JsObject(Context context) {
        this.mContext = context;
    }
    /**
     * 跳转界面
     */
    @JavascriptInterface
    public void start(String flag, String param) {
       
    }
    /**
     * 自动注册返回结果
     */
    @JavascriptInterface
    public void getResult(String result) {
      
    }
    /**
     * 退出当前界面
     */
    @JavascriptInterface
    public void exit() {
       
    }
}

startgetResultexit都是定义给 H5 调用的方法。其中每个方法上面的 @JavascriptInterface都是必须的。H5 方面的部分代码为:

window.javaToJs.getResult("hello");
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值