当前位置:首页 > 开发 > 移动开发 > 正文

Android中webview跟JAVASCRIPT中的交互

发表于: 2011-05-11   作者:jackyrong   来源:转载   浏览:
摘要:   在android的应用程序中,可以直接调用webview中的javascript代码,而webview中的javascript代码,也可以去调用ANDROID应用程序(也就是JAVA部分的代码).下面举例说明之: 1 JAVASCRIPT脚本调用android程序    要在webview中,调用addJavascriptInterface(OBJ,int
  在android的应用程序中,可以直接调用webview中的javascript代码,而webview中的javascript代码,也可以去调用ANDROID应用程序(也就是JAVA部分的代码).下面举例说明之:

1 JAVASCRIPT脚本调用android程序
   要在webview中,调用addJavascriptInterface(OBJ,interfacename)
其中,obj为和javascript通信的应用程序,interfacename为提供给JAVASCRIPT调用的
名称,设置如下:

WebView webView = new WebView(this);
webView.getSettings().setJavaScriptEnabled(true);
webView.loadUrl(getIntent().getCharSequenceExtra("url").toString());
//设定JavaScript脚本代码的界面名称是”android”
webView.addJavascriptInterface(this, "android");
其中WEBVIEW调用的HTML页中,JS如下:
<script type="text/javascript">
function ok() {
  android.js(document.forms[0].elements[0].value, document.forms[0].elements[1].value);
}

而这个android.js在哪呢?那是在应用程序中的
//JavaScript脚本代码可以调用的函数js()处理
public void js(String action, String uri) {
          ...../
}

  这个JS中就是处理JAVASCRIPT发送过来的请求了.

2) 下面的例子,当WEBVIEW网页中输入后,点提交按钮,会跟ANDROID的应用程序进行交互
WebView webView = new WebView(this);
webView.getSettings().setJavaScriptEnabled(true);
webView.setWebChromeClient(new MyWebChromeClient());
webView.loadUrl(getIntent().getCharSequenceExtra("url").toString());

//onJsAlert()函数接收到来自HTML网页的alert()警告信息
public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
if (message.length() != 0) {
AlertDialog.Builder builder = new AlertDialog.Builder(JExample02.this);
builder.setTitle("From JavaScript").setMessage(message).show();
result.cancel();
return true;
}
return false;
}

而HTML页中的JS事件为:
  <input type="button" value="alert" onclick="alert(document.forms[0].elements[0].value)">

特别提示下,在自定义的MyWebChromeClient())中,除了可以重写onJSAlert外,还可以
重写onJsPrompt,onJsConfirm等,可以参考
http://618119.com/archives/2010/12/20/199.html

3) 下面这个例子,先显示第一张图片,点一点后,再显示第2张图片
HTML JS中:
   <script language="javascript">
    function changeImage02() {
        document.getElementById("image").src="navy02.jpg";
    }
    function changeImage01() {
        document.getElementById("image").src="navy01.jpg";
    }
  </script>
</head>
<body>
  <a onClick="window.demo.onClick()">
    <img id="image" src="navy01.jpg"/></a>
</body>

当点<a onClick="window.demo.onClick()">
后,调用ANDROID应用程序中的处理部分,看程序:
     webView.addJavascriptInterface(new JSInterface(),"demo");

public final class JSInterface {
        //JavaScript脚本代码可以调用的函数onClick()处理
        public void onClick() {
            handler.post(new Runnable() {
                public void run() {
                    if (flag == 0) {
                    flag = 1;
                    webView.loadUrl("javascript:changeImage02()");
                    } else {
                    flag = 0;
                    webView.loadUrl("javascript:changeImage01()");
                    }
                }
            });
        }
    }
可以看到,ANDROID中,通过webView.loadUrl去调用HTML页面中的JS

Android中webview跟JAVASCRIPT中的交互

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
欢迎大家访问我的个人网站 萌萌的IT人,后续所有的文章都会在此发布 ------------------------------
转载 http://blog.csdn.net/wangtingshuai/article/details/8635787 最近碰到个新需求需要点击webvi
转载请注明出处 挺帅的移动开发专栏 http://blog.csdn.net/wangtingshuai/article/details/8635787
转载请注明出处 挺帅的移动开发专栏 http://blog.csdn.net/wangtingshuai/article/details/8635787
第一步: 在项目中的assets目录中新建text.html <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01
webview提供了接口让javascript访问Java应用程序,WebView.addJavascriptInterface()方法就是实现交
项目中使用了webview显示网页,其中需要网页和native方法有交互,搜索到一篇文章,转发分享一下: =
  上一篇博文: Android WebView使用基础已经说了一些Android中WebView的基本使用。   本篇文章
本篇文章主要介绍WebView中的JavaScript代码的执行相关,已经JS代码与Android代码的互相调用。   
Android中WebView和JavaScript进行简单通信,源代码链接blog已经给出,可以下载直接运行。 Android提
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号