400-696-8028

Android与JavaScript方法相互调用

长沙北大青鸟作者:科泰校区

摘要: 在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavas criptInterface方法,这样html才能调用android方法,在这里我个人

 在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavas criptInterface方法,这样html才能调用android方法,在这里我个人觉得有点和DWR相似。

为了让大家容易理解,我写了一个简单的Demo,具体步骤如下:

第一步:新建一个Android工程,命名为WebViewDemo(这里我在assets里定义了一个html页面)。

第二步:修改main.xml布局文件,增加了一个WebView控件还有Button控件,代码如下:

1
<?xml version="1.0" encoding="utf-8"?>

第三步:在assets目录下新建一个demo.html文件,代码如下(这里不知道为何多了mce:这几个东东,<s cript></s cript>这样是对的):

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<html>
        <mce:s cript language="javas cript"><!--
      
                function fillContent(){
                        document.getElementById("content").innerHTML =
                             "This Content is showed by Android invoke Javas cript function.";
                }
             
// --></mce:s cript> 
  <body>
        <p><a onClick="window.demo.startMap()" href="">Start GoogleMap</a></p>
        <p id="content"></p>
        <p>A Demo ----Android and Javas cript invoke each other.</p>
        <p>Author:Frankiewei</p>
  </body>
</html>

第四步:修改主核心程序WebViewDemo.java,代码:

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
package com.tutor.webwiewdemo;
import android.app.Activity;
import android.content.ComponentName;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Button;
public class WebViewDemo extends Activity {
        private WebView mWebView;
        private Button mButton;
        public void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.main);
                setupViews();
        }
        //初始化
        private void setupViews() {
                mWebView = (WebView) findViewById(R.id.webview);
                WebSettings mWebSettings = mWebView.getSettings();
                //加上这句话才能使用javas cript方法
                mWebSettings.setJavas criptEnabled(true);
                //增加接口方法,让html页面调用
                mWebView.addJavas criptInterface(new Object() {
                        //这里我定义了一个打开地图应用的方法
                        public void startMap() {
                                Intent mIntent = new Intent();
                                ComponentName component = new ComponentName(
                                                "com.google.android.apps.maps",
                                                "com.google.android.maps.MapsActivity");
                                mIntent.setComponent(component);
                                startActivity(mIntent);
                        }
                }, "demo");
                //加载页面
                mWebView.loadUrl("file:///android_asset/demo.html");
                mButton = (Button) findViewById(R.id.button);
                //给button添加事件响应,执行Javas cript的fillContent()方法
                mButton.setOnClickListener(new Button.OnClickListener() {
                        public void onClick(View v) {
                                mWebView.loadUrl("javas cript:fillContent()");
                        }
                });
        }
}

第五步:运行上述工程,查看效果。


首界面                           点击按钮时,html内容改变


点击html的startGoogleMap启动地图应用

关于我们
公司简介
发展历程
青鸟荣誉
联系我们
加入我们
青鸟课程
BCVE视频特效课程
BCUI全链路UI设计
BCSP软件开发专业
BCNT网络工程师
启能职业教育基础课程
长沙初中生学什么
长沙高中生学什么
长沙大学生学什么