关闭

JavaScript使用localStorage缓存Js和css文件

时间: 2019-02-15阅读: 1210标签: 文件

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

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

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title></head>
    <body>
        <!-- 1.缓存cssjs到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 

 

站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/2028

关闭

html5中利用FileReader来读取文件

利用FileReader来读取文件的能够来实现即时预览的效果,这个也是在html5中才有的功能,readAsText():读取文本文件(可以使用TxT打开的文件),返回文本字符串,默认编码是UTF-8

什么是断点续传?前端如何实现文件的断点续传

什么是断点续传?就是下载文件时,不必重头开始下载,而是从指定的位置继续下载,这样的功能就叫做断点续传。前端通过FileList对象获取到相应的文件,按照指定的分割方式将大文件分段,然后一段一段地传给后端,后端再按顺序一段段将文件进行拼接。

javascript中如何读取文件?

因为JavaScript中的Web API有了新的方法File API,所以我们在浏览器上读取文件并处理数据更加方便而且不需要使用到后端服务器。FileReader就是从一个文件中读取数据并存储在一个JavaScript变量中

vue 查看dist文件里的结构

优化打包后的代码,提高性能。方式一:report-json。package.json文件里加入以下命令,然后控制台运行 npm run report结果:会在dist文件夹里生成 report.json。里面有打包后每个文件的来源。

vue在index.html中引入静态文件不生效

出现该问题的标志如下,控制台warning(Resource interpreted as Stylesheet but transferred with MIME type text/html),第一种可能出现原因就是引入的静态文件在src文件夹内,这种的解决办法就是把资源引入静态资源的目录static

HTML5中FileReader的使用

HTML5定义了FileReader作为文件API的重要成员用于读取文件,FileReader接口提供了读取文件的方法和包含读取结果的事件模型。 FileReader 的实例拥有 4 个方法,其中 3 个用以读取文件,另一个用来中断读取。

TypeScript声明文件

当使用第三方库时,我们需要引用它的声明文件,才能获得对应的代码补全、接口提示等功能。假如我们想使用第三方库 jQuery,一种常见的方式是在 html 中通过 <script> 标签引入 jQuery

前端文件下载的方式

http 头部的 Content-Disposition字段,规定了返回的内容用什么形式展示,前端需要使用window.open 形式访问 此路由就可以实现文件的下载

在js文件中引入另一个js文件的实现方法总汇

比如我写了一个JS文件,这个文件需要调用另外一个JS文件,该如何实现呢?这篇文章主要介绍:在js文件中引入另一个js文件的实现

lock文件_我们为什么需要 lock 文件

从 Yarn 横空出世推出 lock 文件以来,已经两年多时间了,npm 也在 5.0 版本加入了类似的功能,lock 文件越来越被开发者们接收和认可。本篇文章想从前端视角探讨一下我们为什么需要 lock 文件,以及它的一些成本与风险,当然其中一些观点对于后端也是适用的

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!