WebView的使用
我们在Android中如果希望展示一个网页,基本上都会使用WebView这个组件,它的基本使用也很简单,假如我们希望加载一下百度首页,可以像下面这样写: 首先在layout文件中进行声明
然后在java中进行调用
mWebView = (WebView) findViewById(R.id.webview);
mWebView.loadUrl("file:///android_asset/test.html");//加载本地asset下面的js_java_interaction.html文件
//mWebView.loadUrl("https://www.baidu.com/");//加载本地assets下面的js_java_interaction.html文件
同时,WebView还允许我们对一些默认设置进行修改,例如,我们希望启动对javascript的支持并且可以进行缩放,就需要做如下设置:
// 启用javascript
webView.getSettings().setJavaScriptEnabled(true);//打开js支持
webView.getSettings().setUseWideViewPort(true);
但是,如果我们想要在页面加载的时候处理各种通知、请求事件,或者监听页面的加载进度等,就需要用到另外两个类:WebViewClient 和 WebChromeClient。其中,WebViewClient 主要用来监听通知或请求事件:
/**
* 打开js接口給H5调用,参数1为本地类名,参数2为别名;h5用window.别名.类名里的方法名才能调用方法里面的内容,例如:window.android.back();
* */
mWebView.addJavascriptInterface(new JsInteration(), "android");
mWebView.setWebViewClient(new WebViewClient());
mWebView.setWebChromeClient(new WebChromeClient());
/**
* 自己写一个类,里面是提供给H5访问的方法
* */
public class JsInteration {
@JavascriptInterface//一定要写,不然H5调不到这个方法
public String back() {
return "我是java里的方法返回值";
}
}
在js中调用android中的方法
//调用原生的方法,android为约定的别名;back()为原生的方法
var result=window.android.back();
//将返回结果显示在id为p的控件上
document.getElementById("p").innerHTML=result;