zoukankan      html  css  js  c++  java
  • JavaScript使用localStorage缓存Js和css文件

    对于WebApp来说,将js css文件缓存到localstorage区可以减少页面在加载时与HTTP请求的交互次数,从而优化页面的加载时间.特别是当移端信号不好高延迟时优化效果还是很显见的

    下面的代码可以实现此功能:

    <!DOCTYPE html>
    <html lang="en">
        <head>
            <meta charset="UTF-8">
            <title>Document</title></head>
        <body>
            <!-- 1.缓存css、js到LocalStorage 2.调用本地缓存css/js拼接到HTML页面 -->
            <script type="text/javascript">//入口函数
                if (window.localStorage) {
                    initJs();
                    initCss("css", "reset.css");
                } else {
                    alert("不能使用本地缓存");
                    addFile("http://libs.baidu.com/jquery/2.0.0/jquery.min.js", "js");
                    addFile("/gfdzp201508257998/Turntable/Script/whir.turntable.js", "js");
                    addFile("/gfdzp201508257998/Turntable/Style/css_whir.css", "css");
                }
    
                //第一步:加载页面js:先加载jQuery后加载用户脚本
                function initJs() {
                    var name = "jquery"; //存储key的name
                    var url = "js/jquery-1.9.1.min.js";
                    var xhr;
                    var js = window.localStorage ? localStorage.getItem(name) : "";
                    if (js == null || js.length == 0) {
                        if (window.ActiveXObject) {
                            xhr = new ActiveXObject("Microsoft.XMLHTTP");
                        } else if (window.XMLHttpRequest) {
                            xhr = new XMLHttpRequest();
                        }
                        xhr.open("GET", url);
                        xhr.send(null);
                        xhr.onreadystatechange = function() {
                            if (xhr.readyState == 4 && xhr.status == 200) {
                                js = xhr.responseText;
                                localStorage.setItem(name, js);
                                js = js == null ? "": js;
                                addTxt(js, "js");
                                initTurntable(); //确保先引用Jquery
                            }
                        };
                    } else {
                        addTxt(js, "js");
                        initTurntable();
                    }
                }
    
                //加载自定义脚本
                function initTurntable() {
                    var name = "zidingyi";
                    var url = "js/zidingyi.js";
                    var xhr;
                    var js = window.localStorage ? localStorage.getItem(name) : "";
                    if (js == null || js.length == 0) {
                        if (window.ActiveXObject) {
                            xhr = new ActiveXObject("Microsoft.XMLHTTP");
                        } else if (window.XMLHttpRequest) {
                            xhr = new XMLHttpRequest();
                        }
                        xhr.open("GET", url);
                        xhr.send(null);
                        xhr.onreadystatechange = function() {
                            if (xhr.readyState == 4 && xhr.status == 200) {
                                js = xhr.responseText;
                                localStorage.setItem(name, js);
                                js = js == null ? "": js;
                                addTxt(js, "js");
                            }
                        };
                    } else {
                        addTxt(js, "js");
                    }
                }
    
                //第二步:初始化Css
                function initCss(name, url) {
                    var xhr;
                    var css = window.localStorage ? localStorage.getItem(name) : "";
                    if (css == null || css.length == 0) {
                        if (window.ActiveXObject) {
                            xhr = new ActiveXObject("Microsoft.XMLHTTP");
                        } else if (window.XMLHttpRequest) {
                            xhr = new XMLHttpRequest();
                        }
                        xhr.open("GET", url);
                        xhr.send(null);
                        xhr.onreadystatechange = function() {
                            if (xhr.readyState == 4 && xhr.status == 200) {
                                css = xhr.responseText;
                                localStorage.setItem(name, css);
                                css = css == null ? "": css;
                                css = css.replace(/images//g, "style/images/");
                                addTxt(css, "css");
                            }
                        };
                    } else {
                        css = css.replace(/images//g, "style/images/");
                        addTxt(css, "css");
                    }
                }
    
                //辅助方法1:动态添加js,css文件引用
                function addFile(url, fileType) {
                    var head = document.getElementsByTagName('HEAD').item(0);
                    var link;
                    if (fileType == "js") {
                        link = document.createElement("script");
                        link.type = "text/javascript";
                        link.src = url;
                    } else {
                        link = document.createElement("link");
                        link.type = "text/css";
                        link.rel = "stylesheet";
                        link.rev = "stylesheet";
                        link.media = "screen";
                        link.href = url;
                    }
                    head.appendChild(link);
                }
    
                //辅助方法2:动态添加js,css文件内容 
                function addTxt(text, fileType) {
                    var head = document.getElementsByTagName('HEAD').item(0);
                    var link;
                    if (fileType == "js") {
                        link = document.createElement("script");
                        link.type = "text/javascript";
                        link.innerHTML = text;
                    } else {
                        link = document.createElement("style");
                        link.type = "text/css";
                        link.innerHTML = text;
                    }
                    head.appendChild(link);
                }</script>
        </body>
    </html>

    再看看封装通用插件方法:

    /**
     * 插件功能:使用localStorage缓存js和css文件,减少http请求和页面渲染的时间,使用于web移动端H5页面的制作
     * 使用方法:
     *         1.使用此插件前,需要给插件的pageVersion变量赋值,建议变量值由服务器后端输出,当需要更新客户资源时,修改变量值即可
     *         2.加载js:由于js加载有顺序要求,所以需要将后加载的脚本作为前一个加载的回调函数参数传入,如:
     *           whir.res.loadJs ("jquery","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);
        }
    };

      调用该插件:

    <script type="text/javascript" src="fengzhuang.js"></script>
    <script type="text/javascript">
    //入口函数
    whir.res.pageVersion = "1002"; //页面版本,用于检测是否需要更新缓存
    whir.res.loadJs("jquery", "js/jquery-1.9.1.min.js",
    function () {
    whir.res.loadJs("zidingyi", "js/zidingyi.js", null);
    });
    whir.res.loadCss("css", "reset.css", null);
    </script>

    电脑端使用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);

    另外:Web移动端使用localStorage缓存Js和css文件 | 强制不要缓存

    1.尽量不把js放在onload事件中,而是放在由用户主动触发的事件
    2.加时间戳,时间不同则会加载js而非使用缓存
    
    强制不要缓存:
    <meta http-equiv=Cache-Control content=no-cache /> 
    必须结合其他:
    <!-- 禁止浏览器从本地缓存中调阅页面。--> 
    <meta http-equiv="pragram" content="no-cache"> 
    <!--网页不保存在缓存中,每次访问都刷新页面。--> 
    <meta http-equiv="cache-control" content="no-cache, must-revalidate"> 
    <!--同上面意思差不多,必须重新加载页面--> 
    <meta http-equiv="expires" content="0"> 
    <!--网页在缓存中的过期时间为0,一旦网页过期,必须从服务器上重新订阅--> 
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    转自:https://blog.csdn.net/qq_29132907/article/details/79390605

    https://www.cnblogs.com/wwdxf/p/6646649.html

    https://www.cnblogs.com/zyjzz/p/6973608.html

  • 相关阅读:
    用户态切换到内核态的3种方式
    vim_action
    import date
    __sizeof__()
    classmethod staticmethod
    Java对对象的引用 不是 引用调用 而是按值引用 Java不存在引用调用
    多线程同步
    Does Hadoop require SSH?
    hdfs namenode出错
    软件项目的一致性语义描述
  • 原文地址:https://www.cnblogs.com/7qin/p/10236737.html
Copyright © 2011-2022 走看看