首頁 > web前端 > html教學 > 无所不能的WebView(二) 在WebView中对html网页中的资源进行加速_html/css_WEB-ITnose

无所不能的WebView(二) 在WebView中对html网页中的资源进行加速_html/css_WEB-ITnose

WBOY
發布: 2016-06-21 08:58:02
原創
1892 人瀏覽過

最近有一个新需求,用手机流量的时候,webview加载页面的时候速度不是很快,能不能将静态文件缓存到sd卡呢,然后下次再访问这个网页的时候,把上次缓存的静态文件从sd卡拖拽过来,不走流量了,这样既省了流量,又让加载速度提升了。下面来写一个小测试吧(js放在在asseat里面)~

shouldInterceptRequest

在API11开始,shouldInterceptRequest被引入,可以解决这一类问题,这个方法可以通知app从本地加载指定的资源,而并非从网络中加载。

WebView请求回网络,返回响应的数据,再调用shouldInterceptRequest方法来替换webView自行加载网络数据的方法,使用app所提供本地数据。WebResourceResponse需要指定MIME类型,编码格式。

    webview.setWebViewClient(new WebViewClient() {       {        @Override        public WebResourceResponse shouldInterceptRequest(WebView view, String url) {           return replaceJs(view, url);        }    });    protected WebResourceResponse replaceJs(WebView view, String url) {        if (url.startsWith("http://img1.cache.netease.com/f2e/lib/js/ne.js")) {            return new WebResourceResponse("text/html", "utf-8",                    FileTool.streamFromAsset(this, "js/hlct-com.js"));        } else {            return null;        }    }public class FileTool {    public static InputStream streamFromAsset(final Context ctx, final String file) {        try {            return ctx.getAssets().open(file);        } catch (Exception ignored) {        }        return null;    }}
登入後複製

通过以上的代码就可以对webview中的js资源替换掉了。但加快网页打开的同时会增加app的apk包的大小(资源都放在本地了),空间换时间(时间换空间)的选择就看你的了。

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板