最近的项目里用到了混合开发,需要进行 Android 与 JS 的交互,就了解了一下相关知识。
Android 调用 JS 中的方法
布局就不放出来了。
html 代码如下。两个按钮,分别创建两个 script 方法,一个有参,一个无参。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
28
29<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>jsandroid_test</title>
<script type="text/javascript" language="javascript">
function showFromHtml(){
document.getElementById("id_input").value = "Java call Html";
}
function showFromHtml2( param ){
document.getElementById("id_input2").value = "Java call Html : " + param;
}
</script>
</head>
<body>
<input id="id_input" style="width: 90%" type="text" value="null" />
<br>
<input type="button" value="JavacallHtml" onclick="window.jsObj.JavacallHtml()" />
<br>
<input id="id_input2" style="width: 90%" type="text" value="null" />
<br>
<input type="button" value="JavacallHtml2" onclick="window.jsObj.JavacallHtml2()" />
</body>
</html>
android 代码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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57private void showWebView(){ // webView与js交互代码
try {
mWebView = new WebView(this);
setContentView(mWebView);
mWebView.requestFocus(); //触摸焦点起作用,如果不设置,则在点击网页文本输入框时,不能弹出软键盘及不响应其他的一些事件。
// 设置 WebChromeClient
mWebView.setWebChromeClient(new WebChromeClient(){
@Override
public void onProgressChanged(WebView view, int progress){
JSAndroidActivity.this.setTitle("Loading...");
JSAndroidActivity.this.setProgress(progress);
if(progress >= 80) {
JSAndroidActivity.this.setTitle("JsAndroid Test");
}
}
});
WebSettings webSettings = mWebView.getSettings();
webSettings.setJavaScriptEnabled(true); //支持 JavaScript
webSettings.setDefaultTextEncodingName("utf-8");
mWebView.addJavascriptInterface(getHtmlObject(), "jsObj"); //设置 JS 接口,第一个参数是事件接口实例,第二个参数是 实例 在 JS 中的别名
mWebView.loadUrl("http://192.168.1.121:8080/jsandroid/index.html");
} catch (Exception e) {
e.printStackTrace();
}
}
private Object getHtmlObject(){
Object insertObj = new Object(){
public void JavacallHtml(){
runOnUiThread(new Runnable() {
@Override
public void run() {
mWebView.loadUrl("javascript: showFromHtml()");
Toast.makeText(JSAndroidActivity.this, "clickBtn", Toast.LENGTH_SHORT).show();
}
});
}
public void JavacallHtml2(){
runOnUiThread(new Runnable() {
@Override
public void run() {
mWebView.loadUrl("javascript: showFromHtml2('IT-homer blog')");
Toast.makeText(JSAndroidActivity.this, "clickBtn2", Toast.LENGTH_SHORT).show();
}
});
}
};
return insertObj;
}
如上所示,在 JS 中新建两个方法。按钮的点击事件是 window.jsObj.JavacallHtml()
其中 window 代表当前界面,jsObj 是 java 里设置的 JS 接口的别名,JavacallHtml()
是 java 里的方法名字。
JS 调用 Android 中的方法
1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
android 代码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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45private void showWebView(){ // webView与js交互代码
try {
mWebView = new WebView(this);
setContentView(mWebView);
mWebView.requestFocus(); //触摸焦点起作用,如果不设置,则在点击网页文本输入框时,不能弹出软键盘及不响应其他的一些事件。
// 设置 WebChromeClient
mWebView.setWebChromeClient(new WebChromeClient(){
@Override
public void onProgressChanged(WebView view, int progress){
JSAndroidActivity.this.setTitle("Loading...");
JSAndroidActivity.this.setProgress(progress);
if(progress >= 80) {
JSAndroidActivity.this.setTitle("JsAndroid Test");
}
}
});
WebSettings webSettings = mWebView.getSettings();
webSettings.setJavaScriptEnabled(true); //支持 JavaScript
webSettings.setDefaultTextEncodingName("utf-8");
mWebView.addJavascriptInterface(getHtmlObject(), "jsObj"); //设置 JS 接口,第一个参数是事件接口实例,第二个参数是 实例 在 JS 中的别名
mWebView.loadUrl("http://192.168.1.121:8080/jsandroid/index.html");
} catch (Exception e) {
e.printStackTrace();
}
}
private Object getHtmlObject(){
Object insertObj = new Object(){
public String HtmlcallJava(){
return "Html call Java";
}
public String HtmlcallJava2(final String param){
return "Html call Java : " + param;
}
};
return insertObj;
}
WebViewClient与WebChromeClient的区别
WebViewClient主要帮助WebView处理各种通知、请求事件的,比如:onLoadResource, onPageStart,onPageFinish, onReceiveError, onReceivedHttpAuthRequest, shouldOverrideUrlLoading, 可以进行 url 的跳转链接等处理。
WebChromeClient主要辅助WebView处理JavaScript的对话框、网站图标、网站title、加载进度等比如 onCloseWindow, onCreateWindow,onJsAlert,onProgressChanged, onReceivedTitle 等。