WebView与Javascript交互

Android中可以使用WebView加载网页,同时Android端的java代码可以与网页上的javascript代码之间相互调用。

效果图webview的图片中点击,出发js方法,得到图片数据

  1. 画布局就省略了啊
  2. `@SuppressLint({“SetJavaScriptEnabled”, “AddJavascriptInterface”})
    @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    webView=(WebView)findViewById(R.id.webView);
    webView.setVerticalScrollbarOverlay(true);
    //设置WebView支持JavaScript
    webView.getSettings().setJavaScriptEnabled(true);
    String url = “http://undefined.cunite.cn/test/gallery.html“;
    String url2 = “http://undefined.cunite.cn/a.html“;
    webView.loadUrl(url);

    //在js中调用本地java方法
    webView.addJavascriptInterface(new JsInterface(this), "AndroidWebView");
    //添加客户端支持
    webView.setWebChromeClient(new WebChromeClient());
    

    }

     private class JsInterface {
        private Context mContext;

        public JsInterface(Context context) {
            this.mContext = context;
        }

        //在js中调用window.AndroidWebView.gallery(json),便会触发此方法。
        @JavascriptInterface
        public void gallery(String json) {
          //  Toast.makeText(mContext, gallery_json, Toast.LENGTH_SHORT).show();
            Log.i("gallery",json);
        }
    }

这样就可以在js中调用java 的同名方法了

在js中这个方法是这样子的:
window.AndroidWebView.gallery(json);

这时候当我们在手机中点击webview上边的图片,就会调用js中的gallery(json) 这个方法。
这时候就会有如下打印
{
“current”: 2,
“total”: 12,
“list”: [
“Source_new/pic/1.jpg”,
“Source_new/pic/2.jpg”,
“Source_new/pic/3.jpg”,
“Source_new/pic/4.jpg”,
“Source_new/pic/5.jpg”,
“Source_new/pic/6.jpg”,
“Source_new/pic/7.jpg”,
“Source_new/pic/8.jpg”,
“Source_new/pic/9.jpg”,
“Source_new/pic/10.jpg”,
“Source_new/pic/11.jpg”,
“Source_new/pic/12.jpg”
]
}
我们就可以取其中的数据了

特此鸣谢:http://itfish.net/article/25514.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 中,WebView 是一个内置的浏览器控件,可以加载网页并在应用程序中显示。WebViewJavaScript交互是常见的需求,主要有以下几种方式: 1. 通过 WebView 中的 loadUrl() 方法调用 JavaScript 函数。 可以使用 WebView 的 loadUrl() 方法加载一个包含 JavaScript 代码的 URL,实现与 JavaScript交互。例如,在 JavaScript 中定义一个函数: ```javascript function showToast(message) { alert(message); } ``` 然后在 Android 中使用 loadUrl() 方法调用这个函数: ```java webView.loadUrl("javascript:showToast('Hello World!')"); ``` 2. 在 WebView 中启用 JavaScript,并使用 addJavascriptInterface() 方法将 Java 对象注入到 JavaScript 中。 可以在 WebView 中启用 JavaScript 支持,并使用 addJavascriptInterface() 方法将 Java 对象注入到 JavaScript 中。这样,JavaScript 就可以调用 Java 对象的方法。例如,在 Java 中定义一个类: ```java public class MyJavaScriptInterface { private Context context; public MyJavaScriptInterface(Context context) { this.context = context; } @JavascriptInterface public void showToast(String message) { Toast.makeText(context, message, Toast.LENGTH_SHORT).show(); } } ``` 然后在 WebView 中启用 JavaScript 支持,并将 MyJavaScriptInterface 对象注入到 JavaScript 中: ```java webView.getSettings().setJavaScriptEnabled(true); webView.addJavascriptInterface(new MyJavaScriptInterface(this), "Android"); ``` 在 JavaScript 中就可以调用 MyJavaScriptInterface 对象的 showToast() 方法: ```javascript Android.showToast("Hello World!"); ``` 3. 使用 evaluateJavascript() 方法执行 JavaScript 代码并获取返回值。 可以使用 WebView 的 evaluateJavascript() 方法执行 JavaScript 代码,并通过回调函数获取返回值。例如,在 JavaScript 中定义一个函数: ```javascript function add(a, b) { return a + b; } ``` 然后在 Android 中使用 evaluateJavascript() 方法执行这个函数,并获取返回值: ```java webView.evaluateJavascript("add(1, 2)", new ValueCallback<String>() { @Override public void onReceiveValue(String value) { // value = "3" } }); ``` 以上就是 WebViewJavaScript交互方式,开发者可以根据需求选择适合自己的方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值