WebView的缓存可以分为页面缓存和数据缓存。
页面缓存是指加载1个网页时的html、JS、CSS等页面或资源数据。这些缓存资源是由于阅读器的行动而产生,开发者只能通过配置HTTP响应头影响阅读器的行动才能间接地影响到这些缓存数据。
那末相干的缓存到的地址目录是:
要求的Url记录是保存在webviewCache.db里,而url的内容是保存在webviewCache文件夹下.
缓存构成
/data/data/package_name/cache/
/data/data/package_name/database/webview.db
/data/data/package_name/database/webviewCache.db
缓存模式(5种)
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,都使用缓存中的数据。
如:www.taobao.com的cache-control为no-cache,在模式LOAD_DEFAULT下,不管如何都会从网络上取数据,如果没有网络,就会出现毛病页面;在LOAD_CACHE_ELSE_NETWORK模式下,不管是不是有网络,只要本地有缓存,都使用缓存。本地没有缓存时才从网络上获得。
www.360.com.cn的cache-control为max-age=60,在两种模式下都使用本地缓存数据。
总结:根据以上两种模式,建议缓存策略为,判断是不是有网络,有的话,使用LOAD_DEFAULT,无网络时,使用LOAD_CACHE_ELSE_NETWORK。
WebSettings webSettings = tqWebView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setDomStorageEnabled(true);
webSettings.setDatabaseEnabled(true);
webSettings.setAppCacheEnabled(true);
webSettings.setRenderPriority(RenderPriority.HIGH); //提高渲染的优先级
lng = String.valueOf(VehicleApp.getInstance().getVehicleLng());
lat = String.valueOf(VehicleApp.getInstance().getVehicleLat());
if(CommonUtils.hasNetwork(getActivity())){
webSettings.setCacheMode(WebSettings.LOAD_DEFAULT);
Preference.putString("cacheLat",lat);
Preference.putString("cacheLng",lng);
}else{
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
lat=Preference.getString("cacheLat");
lng=Preference.getString("cacheLng");
}
tqWebView.loadUrl("http://xxxxxx.html?longitude=" + lng + "&latitude=" + lat);
tqWebView.getSettings().setLoadsImagesAutomatically(true);
tqWebView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
// 返回值是true的时候控制去WebView打开,为false调用系统阅读器或第3方阅读器
view.loadUrl(url);
return true;
}
});
tqWebView.addJavascriptInterface(this, "demo");
tqWebView.setWebChromeClient(new WebChromeClient());