WebView怎么获取Html元素的值?

 我来答
HY黄小小
2018-02-17 · TA获得超过7284个赞
知道大有可为答主
回答量:1686
采纳率:52%
帮助的人:267万
展开全部
只能通过JavaScript来获取, 然后通过JS获取, 然后通过JavaScriptInterface来传递给Java层。

做webview,遇到2种需求,一种是在自己服务器上的HTML中获取数据,另一种是通过自己服务器上的HTML中的超链接跳到另一个站点的HTML中,并获取数据。
于是,总结了2种通过webview获取网页上的数据的方式:
第一种:简单点的,直接通过js调java,在调用方法的过程中将数据通过方法的参数传递给Android端,(前提:服务端有对应的faxun对象,而且调用的方法是showImages(String[] imgUrls))。

class MyJavaScriptInterface {

MyJavaScriptInterface() {
}

/**
* js调java,显示图片
*
* @param imgUrls
*/
@JavascriptInterface
public void showImages(String[] imgUrls) {
LogUtils.i(TAG, "imgUrls = " + imgUrls[0]);
NewsDetailWebviewActivity.this.imgUrls = imgUrls;
}
}

...
webView.addJavascriptInterface(new MyJavaScriptInterface(), "faxun");

第二种:有点复杂,通过webview注册一个本地接口后,然后通过java调js,拿到document对象后,解析HTML标签,然后数据会通过本地接口中的回调方法传递给Android端,(前提:HTML页面中的meta标签中有对应的reply_info名称和content属性,数据是封装在content里面的json格式的字符串)。

class MyWebClient extends WebViewClient {
@Override
public void onPageFinished(WebView view, String url) {
view.loadUrl("javascript:window.getShareData.OnGetShareData("
+ "document.querySelector('meta[name=\"reply_info\"]').getAttribute('content')" + ");");
super.onPageFinished(view, url);
}
}

private class GetShareDataInterface {
@JavascriptInterface
public void OnGetShareData(String shareData) {
if (null != shareData) {
try {
JSONObject shareJson = new JSONObject(shareData);
title = shareJson.optString("title");
description = shareJson.optString("description");
imageUrl = shareJson.optString("imageUrl");
} catch (JSONException e) {
e.printStackTrace();
}

}
}
}

.....
webView.setWebViewClient(new MyWebClient());

其实,如果是普通的需求,两种方式都可以解决问题,但是如果是有些HTML没有做js调java,只是个普通的HTML,并且需要获取页面上的数据时,只能通过第二种方式来获取HTML上的数据了,比如获取HTML上的title等等。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式