安卓原生和 H5 交互

1.安卓调用 H5 的方法:

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

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

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

1
2
3
4
5
6
7
8
9
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 代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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 方面的部分代码为:

1
window.javaToJs.getResult("hello");