乐虎游戏|乐虎国际登录|欢迎你

Android WebView基本使用

日期:2020-03-15编辑作者:计算机资讯

转载请注明出处:

WebView 使用简介

http://blog.csdn.net/lowprofile_coding/article/details/77928614

一 WebView 相关的类

WebView介绍

Android WebView在Android平台上是一个特殊的View, 基于webkit引擎、展现web页面的控件,这个类可以被用来在你的app中仅仅显示一张在线的网页,还可以用来开发浏览器。WebView内部实现是采用渲染引擎来展示view的内容,提供网页前进后退,网页放大,缩小,搜索。Android的Webview在低版本和高版本采用了不同的webkit版本内核,4.4后直接使用了Chrome。

现在很多APP都内置了Web网页,比如说很多电商平台,淘宝、京东、聚划算等等。WebView比较灵活,不需要升级客户端,只需要修改网页代码即可。一些经常变化的页面可以用WebView这种方式去加载网页。例如中秋节跟国庆节打开的页面不一样,如果是用WebView显示的话,只修改修改html页面就行,而不需要升级客户端。

Webview功能强大,可以直接使用html文件(本地sdcard/assets目录),还可以直接加载url,使用JavaScript可以html跟原生APP互调。

1. WebView

用来显示网页,使用必须时刻注意我们需要添加网络权限

<uses-permission android:name="android.permission.INTERNET"/>

加载网页:

webView.loadUrl("http://www.baidu.com/");

加载本地网页, 网页放在 assets/html 目录下,

mWebView.loadUrl("file:///android_asset/html/hello.html");

加载html四种方式

webView.loadUrl("http://139.196.35.30:8080/OkHttpTest/apppackage/test.html");//加载urlwebView.loadUrl("file:///android_asset/test.html");//加载asset文件夹下html//方式3:加载手机sdcard上的html页面webView.loadUrl("content://com.ansen.webview/sdcard/test.html");//方式4 使用webview显示html代码webView.loadDataWithBaseURL(null,"<html><head><title> 欢迎您 </title></head>" + "<body><h2>使用webview显示 html代码</h2></body></html>", "text/html" , "utf-8", null);

2. WebSettings

对WebView进行配置和管理. WebView 在生成的时候默认生成WebSettings,通过 mWebView.getSettings 获取WebSettings。
如果WebView 销毁,这时候调用WebSettings 方法会出错。

WebSettings webSettings = mWebView.getSettings();

// 允许javascript 调用
webSettings.setJavaScriptEnabled(true);
webSettings.setAllowFileAccess(true);
webSettings.setBuiltInZoomControls(true);
webSettings.setJavaScriptCanOpenWindowsAutomatically(true);

// WebView 默认视频播放必须由用户的手势触发,设置为false 可以在js中 设置进入网页立即播放视频
webSettings.setMediaPlaybackRequiresUserGesture(false);

WebViewClient与WebChromeClient区别

使用WebView基本都会使用这两个类,那他们有哪些区别呢?

WebViewClient主要帮助WebView处理各种通知、请求事件的,有以下常用方法:

  • onPageFinished 页面请求完成
  • onPageStarted 页面开始加载
  • shouldOverrideUrlLoading 拦截url
  • onReceivedError 访问错误时回调,例如访问网页时报错404,在这个方法回调的时候可以加载错误页面。

WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等,有以下常用方法。

  • onJsAlert webview不支持js的alert弹窗,需要自己监听然后通过dialog弹窗
  • onReceivedTitle 获取网页标题
  • onReceivedIcon 获取网页icon
  • onProgressChanged 加载进度回调

3. WebViewClient

WebViewClient 处理WebView 各种通知 & 请求事件
直接通过WebView loadUrl 会跳转到手机的浏览器, 如果需要WebView 本身显示网页,需要在WebViewClient 的
shouldOverrideUrlLoading 中拦截。

mWebView.setWebViewClient(new NmWebViewClient ());

private class NmWebViewClient extends WebViewClient {
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
        view.loadUrl(url);
        return true;
    }
}

WebViewClient 的一些回调函数

  1. onPageStarted
  2. onPageFinished
  3. onLoadResource
  4. onReceivedError
  5. shouldOverrideUrlLoading

简单使用

因为需要加载网页url,所以需要在AndroidManifest.xml中添加访问网络权限。

<uses-permission android:name="android.permission.INTERNET" />

布局文件:activity_main.xml

<?xml version="1.0" encoding="utf-8"?><FrameLayout xmlns:andro android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <WebView android: android:layout_width="match_parent" android:layout_height="match_parent"/> <ProgressBar android: style="@android:style/Widget.ProgressBar.Horizontal" android:layout_width="match_parent" android:layout_height="3dip" android:max="100" android:progress="0" android:visibility="gone"/></FrameLayout>

外层FrameLayout,里面有WebView跟ProgressBar,WebView的宽高匹配父类,ProgressBar横向进度条,高度3dip,按照FrameLayout布局规则,ProgressBar会覆盖在WebView之上,默认是隐藏不显示。

MainActivity.java

public class MainActivity extends AppCompatActivity { private WebView webView; private ProgressBar progressBar; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); progressBar= (ProgressBar)findViewById(R.id.progressbar);//进度条 webView =  findViewById(R.id.webview);// webView.loadUrl("file:///android_asset/test.html");//加载asset文件夹下html webView.loadUrl("http://139.196.35.30:8080/OkHttpTest/apppackage/test.html");//加载url //使用webview显示html代码// webView.loadDataWithBaseURL(null,"<html><head><title> 欢迎您 </title></head>" +// "<body><h2>使用webview显示 html代码</h2></body></html>", "text/html" , "utf-8", null); webView.addJavascriptInterface(this,"android");//添加js监听 这样html就能调用客户端 webView.setWebChromeClient(webChromeClient); webView.setWebViewClient(webViewClient); WebSettings webSettings=webView.getSettings(); webSettings.setJavaScriptEnabled;//允许使用js /** * LOAD_CACHE_ONLY: 不使用网络,只读取本地缓存数据 * LOAD_DEFAULT: 根据cache-control决定是否从网络上取数据。 * LOAD_NO_CACHE: 不使用缓存,只从网络获取数据. * LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。 */ webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);//不使用缓存,只从网络获取数据. //支持屏幕缩放 webSettings.setSupportZoom; webSettings.setBuiltInZoomControls; //不显示webview缩放按钮// webSettings.setDisplayZoomControls; } //WebViewClient主要帮助WebView处理各种通知、请求事件 private WebViewClient webViewClient=new WebViewClient(){ @Override public void onPageFinished(WebView view, String url) {//页面加载完成 progressBar.setVisibility(View.GONE); } @Override public void onPageStarted(WebView view, String url, Bitmap favicon) {//页面开始加载 progressBar.setVisibility(View.VISIBLE); } @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { Log.i("ansen","拦截url:"+url); if(url.equals("http://www.google.com/")){ Toast.makeText(MainActivity.this,"国内不能访问google,拦截该url",Toast.LENGTH_LONG).show(); return true;//表示我已经处理过了 } return super.shouldOverrideUrlLoading(view, url); } }; //WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等 private WebChromeClient webChromeClient=new WebChromeClient(){ //不支持js的alert弹窗,需要自己监听然后通过dialog弹窗 @Override public boolean onJsAlert(WebView webView, String url, String message, JsResult result) { AlertDialog.Builder localBuilder = new AlertDialog.Builder(webView.getContext; localBuilder.setMessage.setPositiveButton("确定",null); localBuilder.setCancelable; localBuilder.create; //注意: //必须要这一句代码:result.confirm()表示: //处理结果为确定状态同时唤醒WebCore线程 //否则不能继续点击按钮 result.confirm(); return true; } //获取网页标题 @Override public void onReceivedTitle(WebView view, String title) { super.onReceivedTitle(view, title); Log.i("ansen","网页标题:"+title); } //加载进度回调 @Override public void onProgressChanged(WebView view, int newProgress) { progressBar.setProgress(newProgress); } }; @Override public boolean onKeyDown(int keyCode, KeyEvent event) { Log.i("ansen","是否有上一个页面:"+webView.canGoBack; if (webView.canGoBack() && keyCode == KeyEvent.KEYCODE_BACK){//点击返回按钮的时候判断有没有上一页 webView.goBack(); // goBack()表示返回webView的上一页面 return true; } return super.onKeyDown(keyCode,event); } /** * JS调用android的方法 * @param str * @return */ @JavascriptInterface //仍然必不可少 public void getClient(String str){ Log.i("ansen","html调用客户端:"+str); } @Override protected void onDestroy() { super.onDestroy(); //释放资源 webView.destroy(); webView=null; }}
  • onCreate 查找控件,给webView设置加载url,添加js监听,监听的名称是"android",设置webChromeClient跟webViewClient回调,通过getSettings方法获取WebSettings对象,设置允许加载js,设置缓存模式,支持缩放。
  • webViewClient 重写了几个方法,onPageFinished页面加载完成隐藏进度条,onPageStarted页面开始加载显示进度条,shouldOverrideUrlLoading拦截url,如果请求url是打开google,不让他请求,因为google在国内不能访问,就算请求也请求不到还不如拦截掉,直接告诉用户不能访问。
  • webChromeClient onJsAlert()因为WebView不支持alert弹窗,在这个方法中用AlertDialog去弹窗。onReceivedTitle获取网页标题。onProgressChanged页面加载进度,把加载进度给progressBar。
  • onKeyDown 如果点击系统自带返回键&&webView有上一级页面,调用goBack返回。否则不处理。什么时候辉有上一级页面呢?就是你从首页跳转到了一个新页面,点击返回的时候会返回首页。如果本来就在首页点击返回的时候会退出app。
  • getClient html页面的JS可以通过这个方法回调原生APP,这个方法有个注解@JavascriptInterface,这个是必须的,这个方法有个字符串参数,这个方法跟我们在onCreate中调用addJavascriptInterface传入的name一起使用的。例如html中想要回调这个方法可以这样写:javascript:android.getClient("传一个字符串给客户端");
  • onDestroy activity销毁时释放webView资源。

运行代码,效果图如下:

图片 1效果图

源码下载

 Android开发666 - 安卓开发技术分享 扫描二维码加关注

图片 2Android开发666

4. WebChromeClient

WebChromeClient 处理一些和Js 相关的回调

mWebView.setWebChromeClient(new WebChromeClient(){
    @Override
    public boolean onConsoleMessage(ConsoleMessage consoleMessage) {
        Log.e("onConsoleMessage", consoleMessage.message());
        return super.onConsoleMessage(consoleMessage);
    }
});

WebChromeClient 的一些主要回调方法

  1. onProgressChanged
  2. onConsoleMessage
  3. onReceivedTitle
  4. onJsAlert
  5. onJsConfirm
  6. onJsPrompt
  7. onJsTimeout

本文由乐虎游戏发布于计算机资讯,转载请注明出处:Android WebView基本使用

关键词:

乐虎国际登录:话说Svn与Git的区别(以后别再问我了)

这篇主要是谈谈两者的区别,至于谁优谁劣看官自己思考吧! 最核心的区别Git是分布式的,而Svn不是分布的。能理解...

详细>>

Maven pom 详明

Resources.../Resources Maven 属性默认只有在 pom.xml 中才会被解析,对于放在 src/main/resources/ 目录下的文件,maven 是需要通过...

详细>>

常用Git命令汇总

跟着R哥来到了新公司(一个从硬件向互联网转型中的公司),新公司以前的代码基本是使用SVN做版本控制,所以R哥叫...

详细>>

View 的可知性检查仍然为能够如此~

在Android开发中,我们常常会对View的可视性visiblity进行操作或者检查。如网络请求数据,根据返回的数据结果控制相应...

详细>>