Web移動端使用localStorage緩存Js和CSS文件


將js css文件緩存到localstorage區可以減少頁面在加載時與HTTP請求的交互次數,從而優化頁面的加載時間.

電腦端使用localstorage是測試沒有問題的,但是用android的apk打包之后,導致localstorage失效,無法進行緩存,查閱資料之后,得知解決方法:

安卓代碼:

mWebView.getSettings().setDomStorageEnabled(true);   
mWebView.getSettings().setAppCacheMaxSize(1024*1024*8);  
String appCachePath = getApplicationContext().getCacheDir().getAbsolutePath();  
mWebView.getSettings().setAppCachePath(appCachePath);  
mWebView.getSettings().setAllowFileAccess(true);  

mWebView.getSettings().setAppCacheEnabled(true); 

之后便可以使用localstorage進行緩存,

緩存方法已經封裝成了通用的插件:

具體代碼如下(網上查詢所得):

/**
 * 插件功能:使用localStorage緩存js和css文件,減少http請求和頁面渲染的時間,使用於web移動端H5頁面的制作
 * 使用方法:
 *         1.使用此插件前,需要給插件的pageVersion變量賦值,建議變量值由服務器后端輸出,當需要更新客戶資源時,修改變量值即可
 *         2.加載js:由於js加載有順序要求,所以需要將后加載的腳本作為前一個加載的回調函數參數傳入,如:
 *           whir.res.loadJs ("jquery","<%= BasePath %>TurnTable/Script/jquery.min.js",
 *                             function () {
 *                                 whir.res.loadJs(name,url,null)
 *                             });
 */
var whir = window.whir || {};
whir.res = {
    pageVersion : "",//版本,有頁面輸入,用語刷新localStorage緩存
    loadJs : function (name, url, callback) {//動態加載js文件並緩存
        if (window.localStorage) {
            var xhr;
            var js = localStorage.getItem(name);
            if (js == null || js.length == 0 || this.pageVersion != localStorage.getItem("version")) {
                if (window.ActiveXObject) {
                    xhr = new ActiveXObject("Microsoft.XMLHTTP");
                } else if (window.XMLHttpRequest) {
                    xhr = new XMLHttpRequest();
                }
                if (xhr != null) {
                    xhr.open("GET",url);
                    xhr.send(null);
                    xhr.onreadystatechange = function () {
                        if (xhr.readyState == 4 && xhr.status == 200) {
                            js = xhr.responseText;
                            localStorage.setItem(name,js);
                            localStorage.setItem("version",whir.res.pageVersion);
                            js = js == null ? "" : js;
                            whir.res.writeJs(js);
                            if (callback != null) {
                                callback();
                            }
                        }
                    }
                }
            } else {
                whir.res.writeJs(js);
                if (callback != null) {
                    callback();//回調,執行下一個引用
                }
            }
        } else {
            whir.res.linkJs(url);
        }
    },
    loadCss : function (name,url) {
        if (window.localStorage) {
            var xhr;
            var css = localStorage.getItem(name);
            if (css == null || css.length == 0 || this.pageVersion != localStorage.getItem("version")) {
                if (window.ActiveXObject) {
                    xhr = new ActiveXObject("Microsoft.XNLHTTP");
                } else if (window.XMLHttpRequest) {
                    xhr = new XMLHttpRequest();
                }
                if (xhr != null) {
                    xhr.open("GET",url);
                    xhr.send(null);
                    xhr.onreadystatechange = function () {
                        if (xhr.readyState == 4 && xhr.status == 200) {
                            css = xhr.responseText;
                            localStorage.setItem(name,css);
                            localStorage.setItem("version",whir.res.pageVersion);
                            css = css == null ? "" : css;
                            css = css.replace(/images\//g,"style/images/");//css里的圖片路徑需要單獨處理
                            whir.res.writeCss(css);
                        }
                    }
                }
            } else {
                css = css.replace(/images\//g,"style/images/");//css里的圖片路徑需要單獨處理
                whir.res.writeCss(css);
            }
        } else {
            whir.res.linkCss(url);
        }
    },
    writeJs : function (text) {//往頁面寫入js\腳本
        var head = document.getElementsByTagName('HEAD').item(0);//獲取head
        var link = document.createElement("script");
        link.type = "text/javascript";
        link.innerHTML = text;
        head.appendChild(link);
    },
    writeCss : function (text) {//往頁面寫入css樣式
        var head = document.getElementsByTagName("HEAD").item(0);
        var link = document.createElement("style");
        link.type = "text/css";
        link.innerHTML = text;
        head.appendChild(link);
    },
    linkJs : function (url) {//往頁面引入js
        var head = document.getElementsByTagName('HEAD').item(0);//獲取head
        var link = documenr.createElement("script");
        link.type = "text/javascript";
        link.src = url;
        head.appendChild(link);
    },
    linkCss : function (url) {//往頁面引入css
        var head = document.getElementsByTagName('HEAD').item(0);  
        var link = document.createElement("link");  
        link.type = "text/css";  
        link.rel = "stylesheet";  
        link.rev = "stylesheet";  
        link.media = "screen";  
        link.href = url;  
        head.appendChild(link);
    }
};

第一次加載時可能會慢,第二次就能明顯提升訪問速度...


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM