这段时间基于项目须要 在开发中与WebView的接触比較多,前段时间关于HTML5规范尘埃落定的消息出如今各大IT社区头版上,更有人说:HTML5将颠覆原生App开发 尽管我不太认同这一点 可是关于HTML5+JS+CSS+Native的跨平台开发模式还是为非常多企业节省了开发资源和成本、一定程度上提升了WebView的使用率和地位。

网上关于HTML5规范定稿的一篇见解文章:

http://www.csdn.net/article/2014-11-06/2822513-how-html5-changes

本篇主要基于这段时间对WebView的使用经验和网上学习到的对WebView开发做一个要点小结:

一、WebView基于webkit引擎展现web页面的控件,使用前须要在Android Manifest file中配置internet訪问权限,否则提示页面无法訪问。

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

二、WebView属性的设置

  1、设置WebSettings类

     WebSettings用来对WebView的配置进行配置和管理,比方能否够进行文件操作、缓存的设置、页面是否支持放大和缩小、是否同意使用数据库api、字体及文字编码设置、是否同意js脚本执行、是否同意图片自己主动载入、是否同意数据及password保存等等

     演示样例代码例如以下:

WebSettings webSettings = mWebView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setCacheMode(WebSettings.LOAD_DEFAULT);
webSettings.setDomStorageEnabled(true);
webSettings.setDatabaseEnabled(true);
webSettings.setAppCacheEnabled(true);
webSettings.setAllowFileAccess(true);
webSettings.setSavePassword(true);
webSettings.setSupportZoom(true);
webSettings.setBuiltInZoomControls(true);
/**
* 用WebView显示图片,可使用这个參数 设置网页布局类型:
* 1、LayoutAlgorithm.NARROW_COLUMNS :适应内容大小
* 2、LayoutAlgorithm.SINGLE_COLUMN : 适应屏幕,内容将自己主动缩放
*/
webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);
webSettings.setUseWideViewPort(true); mWebView.setScrollBarStyle(WebView.SCROLLBARS_OUTSIDE_OVERLAY);
mWebView.setHorizontalScrollbarOverlay(true);
mWebView.setHorizontalScrollBarEnabled(true);
mWebView.requestFocus();

2、设置WebChromeClient子类

      WebChromeClient会在一些影响浏览器ui交互动作发生时被调用,比方WebView关闭和隐藏、页面载入进展、js确认框和警告框、js载入前、js操作超时、webView获得焦点等等

mWebView.setWebChromeClient(new MyWebChromeClient());

3、设置WebViewClient子类

     WebViewClient会在一些影响内容渲染的动作发生时被调用,比方表单的错误提交须要又一次提交、页面開始载入及载入完毕、资源载入中、接收到https认证须要处理、页面键盘响应、页面中的url打开处理等等

mWebView.setWebViewClient(new MyWebViewClient());

4、设置addJavascriptInterface方法

     使Js调用Native本地Java对象,实现本地Java代码和HTML页面进行交互,

     注意:由于安全问题的考虑 Google在使用Android API 17以上的版本号的时候 须要通过@JavascriptInterface来注解的Java函数才干被识别能够被Js调用。

三、设置当前网页的链接仍在WebView中跳转,而不是跳到手机浏览器里显示,

       在WebViewClient的子类中重写shouldOverrideUrlLoading函数  代码例如以下:

webView.setWebViewClient(new WebViewClient() {  

    @Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
});

shouldOverrideUrlLoading表示当前webView中的一个新url须要载入时,给当前应用程序一个处理机会,假设没有重写此函数,webView请求ActivityManage选择合适的方式处理请求,就像弹出uc和互联网让用户选择浏览器一样。重写后return true表示让当前程序处理,return false表示让当前webView处理



四、设置開始载入网页、载入完毕、载入错误时处理

   在WebViewClient子类中分别重写例如以下父类函数  代码例如以下:

webView.setWebViewClient(new WebViewClient() {  

    @Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
// 開始载入网页时处理 如:显示"载入提示" 的载入对话框
DialogManager.showLoadingDialog(this);
} @Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
// 网页载入完毕时处理 如:让 载入对话框 消失
DialogManager.dismissLoadingDialog();
} @Override
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
super.onReceivedError(view, errorCode, description, failingUrl);
// 载入网页失败时处理 如:
view.loadDataWithBaseURL(null,
"<span style=\"color:#FF0000\">网页载入失败</span>",
"text/html",
"utf-8",
null);
}
});

五、处理https请求,为WebView处理ssl证书设置

    WebView默认是不处理https请求的,页面显示空白,须要进行例如以下设置

    在WebViewClient子类中重写父类的onReceivedSslError函数  代码例如以下:

webView.setWebViewClient(new WebViewClient() {  

    @Override
public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
handler.proceed(); // 接受信任全部站点的证书
// handler.cancel(); // 默认操作 不处理
// handler.handleMessage(null); // 可做其它处理
}
});

六、显示页面载入进度

   在WebChromeClient子类中重写父类的onProgressChanged函数  代码例如以下:

webView.setWebChromeClient(new WebChromeClient() {  

    public void onProgressChanged(WebView view, int progress) {
setTitle("页面载入中,请稍候..." + progress + "%");
setProgress(progress * 100); if (progress == 100) {
setTitle(R.string.app_name);
}
}
});

onProgressChanged通知应用程序当前页面载入的进度

progress表示当前页面载入的进度,为1至100的整数



七、back键控制网页后退

   Activity默认的back键处理为结束当前Activity,WebView查看了非常多网页后,希望按back键返回上一次浏览的页面,这个时候我们就须要覆盖WebView所在Activity的onKeyDown函数,告诉他怎样处理,代码例如以下:

public boolean onKeyDown(int keyCode, KeyEvent event) {
if (webView.canGoBack() && event.getKeyCode() == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) {
webView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}

当中webView.canGoBack()在webView含有一个可后退的浏览记录时返回true

webView.goBack();表示返回至webView的上次訪问页面

八、使用addJavascriptInterface完毕和js交互

1、Js中调Native本地Java方法

  设置webView的addJavascriptInterface方法,该方法有两个參数,第一个參数为被绑定到js中的类实例,第二个參数为在js中暴露的类别名,在js中引用java对象就是用这个名字

在Native Java代码例如以下:

mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.addJavascriptInterface(new JavaScriptInterface(this), "Android"); class JavaScriptInterface{ Context mContext; /** Instantiate the interface and set the context */
JavaScriptInterface(Context c) {
mContext = c;
} /** Show a toast from the web page
* 由Js调用运行Native本地Java方法
*/
@JavascriptInterface
public void showToast(String toast) {
Log.d("TAG", "Js Invoker Native Function");
Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
} }

在HTML中Js调用Native方法 代码例如以下:

<input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" />

<script type="text/javascript">
function showAndroidToast(toast) {
Android.showToast(toast);
}
</script>

2、Java调Js方法

比方在HTML中有例如以下Js函数

<script type="text/javascript">
function showAlert() {
alert("Be executed by Native");
}
</script>

在Native调Js方法例如以下:

mWebView.loadUrl("javascript:showAlert()");

九、WebView缓存模式的设置

1、网页数据缓存

当使用WebView载入HTML网页时,会在我们data/应用package下生成database与cache两个目录:

我们请求的Url记录是保存在webviewCache.db里,而url的内容是保存在webviewCache目录下.



五种缓存模式的设置setCacheMode:

LOAD_CACHE_ONLY:  不使用网络,仅仅读取本地缓存数据。

LOAD_DEFAULT:  依据cache-control决定是否从网络上取数据。

LOAD_CACHE_NORMAL: API level 17中已经废弃, 从API level 11開始作用同LOAD_DEFAULT模式。

LOAD_NO_CACHE: 不使用缓存,仅仅从网络获取数据。

LOAD_CACHE_ELSE_NETWORK,仅仅要本地有,不管是否过期,或者no-cache,都使用缓存中的数据。



如演示样例代码:

WebSettings webSettings = mWebView.getSettings();
webSettings.setCacheMode(WebSettings.LOAD_DEFAULT); //设置 缓存模式
// 开启 DOM storage API 功能
webSettings.setDomStorageEnabled(true);
//开启 database storage API 功能
webSettings.setDatabaseEnabled(true);

2、H5缓存

通过setAppCacheEnabled(boolean flag)设置H5的缓存是否打开,默认关闭。

依据setAppCachePath(String appCachePath)提供的路径,在H5使用缓存过程中生成的缓存文件。

通过setAppCacheMaxSize(long appCacheMaxSize)设置缓存最大容量。



如演示样例代码:

String cacheDirPath = getCacheDir().getAbsolutePath()+ "/webViewCache ";
WebSettings webSettings = mWebView.getSettings();
//开启 database storage API 功能
webSettings.setDatabaseEnabled(true);
//设置数据库缓存路径
webSettings.setDatabasePath(cacheDirPath);
//开启Application H5 Caches 功能
webSettings.setAppCacheEnabled(true);
//设置Application Caches 缓存文件夹
webSettings.setAppCachePath(cacheDirPath);

十、加快HTML网页载入完毕速度

    默认情况html代码下载到WebView后,webkit開始解析网页各个节点,发现有外部样式文件或者外部脚本文件时,会异步发起网络请求下载文件,但假设在这之前也有解析到image节点,那势必也会发起网络请求下载对应的图片。在网络情况较差的情况下,过多的网络请求就会造成带宽紧张,影响到css或js文件载入完毕的时间,造成页面空白loading过久。解决办法就是告诉WebView先不要自己主动载入图片,等页面finish后再发起图片载入。

    故在WebView初始化时设置例如以下代码:

public void int () {
if(Build.VERSION.SDK_INT >= 19) {
webView.getSettings().setLoadsImagesAutomatically(true);
} else {
webView.getSettings().setLoadsImagesAutomatically(false);
}
}

同一时候在WebView的WebViewClient子类中重写onPageFinished()方法加入例如以下代码:

@Override
public void onPageFinished(WebView view, String url) {
if(!webView.getSettings().getLoadsImagesAutomatically()) {
webView.getSettings().setLoadsImagesAutomatically(true);
}
}

从上面的代码,能够看出我们对系统API在19以上的版本号作了兼容。由于4.4以上系统在onPageFinished时再恢复图片载入时,假设存在多张图片引用的是同样的src时,会仅仅有一个image标签得到载入,因而对于这种系统我们就先直接载入。

十一、WebView硬件加速导致页面渲染闪烁问题解决方法

    关于Android硬件加速 開始于Android 3.0 (API level 11),在四个级别上开启/关闭硬件加速

    1、Application级别:为整个应用程序开启硬件加速,在AndroidManifest中增加例如以下配置

<application android:hardwareAccelerated="true" ...>

2、Activity级别:控制每一个activity是否开启硬件加速,仅仅需在activity元素中加入android:hardwareAccelerated属性就可以

<activity android:hardwareAccelerated="true" ...>

3、Window级别:注:眼下还不支持在Window级别上关闭硬件加速

getWindow().setFlags(
WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED,
WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED);

4、View级别:执行时单个view硬件加速,眼下Android还不支持在View级别开启硬件加速  代码例如以下:

mView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);

[//TODO 关于Android硬件加速 小吕有时间会更具体的单独整理成一篇来做介绍 

     先提供学习地址:http://android.toolib.net/guide/topics/graphics/hardware-accel.html]



     我们开启硬件加速后,WebView渲染页面更加高速,拖动也更加顺滑。但有个副作用就是easy会出现页面载入白块同一时候界面闪烁现象。解决问题的方法是设置WebView临时关闭硬件加速 代码例如以下:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
webview.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
}

十二、WebView载入本地HTML文件乱码问题解决方式

分析一、保证html页面有设置编码格式 如:

<meta http-equiv="content-type" content="text/html;charset=utf-8"/>

分析二、为WebView 指定显示的编码,WebView设置编码是在Settings中来设置,如:         

mWebView.getSettings().setDefaultTextEncodingName("utf-8");

分析三、假设你是使用的loadData()来载入显示网页。中文出现乱码 则改为loadDataWithBaseURL

             原因:webview.loadData方法不支持中文解析,通经常使用webView.loadDataWithBaseURL来解决。如:          

//webview.loadData(data, "text/html", "utf-8");
webview.loadDataWithBaseURL(baseUrl, data, "text/html", "utf-8", failUrl);

十三、其它注意事项:

1> 从网络上下载html页面的过程应放在工作线程(后台线程)中

    2> html下载成功后渲染出html的步骤应放在UI主线程,不然WebView载入网页过程会easy报错

Android学习之 WebView使用小结的更多相关文章

  1. android学习笔记WebView的基本使用

    WebView可以看做是一个浏览器,它使用了WebKit渲染引擎加载显示网页. WebView的使用需要掌握下面几点, 1,首先需要开启应用网络访问权限 在AndroidMinafest.xml中添加 ...

  2. 十、Android学习第九天——小结(转)

    (转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 十.Android学习第九天——小结 通过这段时间的学习,今晚上来做个小小 ...

  3. Android 学习笔记之网络通信基础+WebView....

    PS:加快学习进度...下周一完成Android网络通信...然后正式进入实战... 学习内容: 1.Android中Http基础... 2.Android中的Socket基础... 3.Androi ...

  4. Android学习笔记50:使用WebView控件浏览网页

    在Android中,可以使用Webview控件来浏览网页.通过使用该控件,我们可以自制一个简单的浏览器,运行效果如图1所示. 图1 运行效果 1.WebView 在使用WebView控件时,首先需要在 ...

  5. HTML5学习总结-10 Android 控件WebView显示网页

    WebView可以使得网页轻松的内嵌到app里,还可以直接跟js相互调用. webview有两个方法:setWebChromeClient 和 setWebClient 1)setWebClient: ...

  6. 安卓开发学习笔记(五):史上最简单且华丽地实现Android Stutio当中Webview控件https/http协议的方法

    一.我们先在XML当中自定义一个webview(Second_layout.xml) 代码如下: <?xml version="1.0" encoding="utf ...

  7. Android学习笔记_32_通过WebView实现JS代码与Java代码互相通信

    webview两种实现方法,覆盖onKeyDown()方法 缓存 WebSettings应用注意的几个问题 1.要实现JS代码与Java代码互相通信,需要通过Android的WebView控件,在视图 ...

  8. 客户端相关知识学习(十一)之Android H5交互Webview实现localStorage数据存储

    前言 最近有一个需求是和在app中前端本地存储相关的,所以恶补了一下相关知识 webView开启支持H5 LocalStorage存储 有些时候我们发现写的本地存储没有起作用,那是因为默认WebVie ...

  9. Android学习系列(40)--Android主题和样式之系统篇(下)

    11)Widget样式(Widget Style) 特别说明,此处定义大量的系统内置控件的样式,对于重写原生控件的样式具有很大的参考价值. <!-- Widget styles --> & ...

随机推荐

  1. 使用js在新窗口中POST数据

    最近在做自己的博客,写文章的时候有一个预览功能,当时使用的是弹出框来进行预览,感觉体验不是很好. 然后想到了写邮件时候的新窗口预览,查了下126邮箱和qq邮箱的预览实现效果,以及各种谷歌百度stack ...

  2. SUPPORTDIR引用的文件的加入

    上一篇转载了SUPPORTDIR的理论解释,如今截图说明实际操作: 选择依赖的语言,在右面的files框里右键点击,选择Insert Files插入文件,编译.由于安装得时候,压缩包会解压成一个暂时文 ...

  3. gradle--java入门(转)

    7.3.3 项目之间的依赖性 您可以添加项目之间的依赖性在相同的构建,所以,例如,这个一个项目的JAR文件是用来编译另一个项目,在api构建文件我们将添加一个依赖JAR产生的共享项目.由于这种依赖性, ...

  4. Event Sourcing - ENode(二)

    接上篇文章继续 http://www.cnblogs.com/dopeter/p/4899721.html 分布式系统 前篇谈到了我们为何要使用分布式系统,因为ENode本身就是一个分布式的框架.看了 ...

  5. css3 翻牌(rotate) 以及翻转 导致边缘锯齿解决 方法

     主要知识点:rotate旋转以及  outline透明的像素消除(明显降低)火狐旋转是产生的 锯齿  首先看结构: <li class="flip-container " ...

  6. 据序和中序序列或者也许为了一个二进制序列,恢复二进制和打印图像(c语言)

    首先要预购和序,以恢复它: 1.首先,我们使用的是递归的方式来完成 2.递归的最小单位:一个空的树和书的前言和第一序.该序列的第一个元素是树的第一序列根,调用这种方法 3.递归的终止条件是.当这棵树的 ...

  7. oracle connect by 说明

    Oracle能够通过START WITH . . . CONNECT BY . . .子句来实现SQL分层查询,这递归查询 例如: select level||'月' 月份 from dual con ...

  8. spring整合JMS - 基于ActiveMQ实现

    一. 开篇语 继上一篇apache ActiveMQ之初体验后, 由于近期一直在复习spring的东西, 所以本文就使用spring整合下JMS. 二. 环境准备 1. ActiveMQ5.2.0 ( ...

  9. hdu 1150 Machine Schedule (经典二分匹配)

    //A组n人 B组m人 //最多有多少人匹配 每人仅仅有匹配一次 # include<stdio.h> # include<string.h> # include<alg ...

  10. jQuery语音播放插件

    自己做jQuery插件:将audio5js封装成jQuery语音播放插件   日前的一个项目需要用到语音播放功能.发现Audio5js符合需求且使用简单,又鉴于jQuery控件便于开发操作,于是有了以 ...