zoukankan      html  css  js  c++  java
  • Android中webview跟JAVASCRIPT中的交互

      在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风之境地 java-javascript 蘑菇街女装

  • 相关阅读:
    指定时间的月初和月末一天的写法
    EF写distinct
    服务的调试和安装
    EF写INNER JOIN 链接
    BZOJ 1825: [JSOI2010]蔬菜庆典
    P4171 [JSOI2010]满汉全席
    Educational Codeforces Round 71 (Rated for Div. 2) Solution
    P4292 [WC2010]重建计划
    P3724 [AH2017/HNOI2017]大佬
    P5504 [JSOI2011]柠檬
  • 原文地址:https://www.cnblogs.com/sky7034/p/2044026.html
Copyright © 2011-2022 走看看