定义
一个view控件用于加载web页面(目前比较流行的H5页面)
需要的权限
webview显然是网络请求的控件,所以使用时必须加入网络请求
<user-permission android:name="android.permission.INTERNET"/>
用法
a ) 用手机自带的浏览器中打开目标链接
Uri uri = Uri.parse("http://www.example.com");
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);
b ) 在activity组件中显示webview
WebView webview = new WebView(this);
//或者有webview = findviewbyid(R.id.....)
setContentView(webview);
有目标网络地址:webview.loadUrl(要加载的网络地址);
// OR, you can also load from an HTML string:
直接拼接字符串形成前端页面
String summary = "You scored 192";
webview.loadData(summary, "text/html", null);
c )在webview中添加自己的行为用法:
c.1 执行浏览器的UI变化,比如进度条和alert的通知窗口,
可以给webview如下设置
webchromeClient,这时会调用webchromeClient的方法
getWindow().requestFeature(Window.FEATURE_PROGRESS);//设置窗口风格为进度条
webview.getSettings().setJavaScriptEnabled(true);//设置页面javascript可用
final Activity activity = this;
//在webchromeClient里设置进度条更新
webview.setWebChromeClient(new WebChromeClient() {
public void onProgressChanged(WebView view, int progress) {
// Activities and WebViews measure progress with different scales.
// The progress meter will automatically disappear when we reach 100%
activity.setProgress(progress * 1000);
}
});
c.2 当网页内容出现加载错误,错误提交或者是响应超链接时,
可以给webview设置一个webviewclient,
超链接会调用webclient里重写的shouldWverrideUrlLoading方法。
下面是一个示例,在一个H5页面上点击一个超链接,获取json数据:
//在webviewClient里处理请求错误
webview.setWebViewClient(new WebViewClient() {
public void onReceivedError(WebView view, int errorCode,
String description, String failingUrl) {
Toast.makeText(activity, "Oh no! " + description,Toast.LENGTH_SHORT).show();
}
});
webview.loadUrl("http://developer.android.com/");
//在webview里响应超链接
webView.getSettings().setJavaScriptEnabled(true);
webView.loadUrl("***********");
webView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view,String url) {
//这里传入的url是响应的超链接url,和webview加载的url不同
if (url != null) {
if ("min://api/getInfo".equals(url)) {
JSONObject jsonObject = new JSONObject();
try {
jsonObject.put("version"
,android.os.Build.VERSION.SDK_INT);
jsonObject.put("man", "min");
} catch (JSONException e) {
e.printStackTrace();
}
//String call = "javascript:alertMessage(\"" + "content" + "\")"; webView.loadUrl(call);
webView.loadUrl("javascript:'"+jsonObject+"'");
Toast.makeText(MainActivity.this, jsonObject.toString(),
Toast.LENGTH_SHORT).show(); }
}
return false;
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
}
});
代码地址
GitHub - wuzhenmin/work-test-demo