android html5页面加载缓存优化

程序猿日常

苦逼的程序员对自己好点!

LZCache使用

https://github.com/wugemu/WebTest

Application中初始化 代码如下:

//初始化
List<String> cacheList=new ArrayList<String>();//缓存的资源
cacheList.add(".js");
cacheList.add(".css");
cacheList.add(".ico");
cacheList.add(".png");//图片
cacheList.add(".jpg");
cacheList.add(".gif");
cacheList.add(".action?");//页面请求
CacheUtil.initOnlyCache(512 * 1024 * 1024, cacheList);//最大缓存512MB

注:讨论 哪些数据进行缓存

initOnlyCache(long cacheMax,List<String> cacheList) 

cacheMax最大缓存容量,只对cacheList中的文件进行缓存(字符串包含)

initAllCache(long cacheMax,List<String> noCacheList)

cacheMax最大缓存容量,只对noCacheList中的文件不进行缓存(字符串包含)

1首次加载优化

CacheUtil.loadUrl(WebView webview, Content content, String url, Map<String ,String> headpara);

该方法实现webview加载与 html内容请求异步,html内容获取后会立即展示,无需等待资源加载完成,并缓存到本地可同步更新,使用此方法可以实现离线模式(缓存文件完全)。

注: html5中有请求时,需要实现跨域设置;

2缓存机制优化

webView.setWebViewClien(new WebViewClientCache());

示例代码如下:

webView.setWebViewClient(new WebViewClientCache(){
    @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
        // TODO Auto-generated method stub
        view.loadUrl(url);
        return true;
    }
    @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);
    }   

});

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

五个木

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值