zoukankan      html  css  js  c++  java
  • 利用 localStorage 储存css js

    链接  版本号, 可以后台输出到jsp页面上

        

    移动端webapp值得一试:
    • 兼容性好
    • 网速慢,LS读取+eval大多数情况下快于304
    • webapp不需要seo,css也可以缓存,再通过js加载
    • 浏览器缓存经常会被清理,LS被清理的几率低一些
    /** 
    * 插件功能:使用localStorage缓存js和css文件,减少http请求和页面渲染时间,适用于Web移动端H5页面制作。 
    * 插件作者:zhangqs008@163.com 
    * 使用方法:   
    *   1.使用此插件前,需要给插件的pageVersion变量赋值,建议变量值由服务器后端输出,当需要更新客户端资源时,修改版本值即可。 
    * 2.加载Js:由于js加载有顺序要求,所以需要将后加载的脚本作为前一个脚本的回调参数传入,如:
    * whir.res.loadJs("jquery", "<%= BasePath %>Turntable/Script/jquery-1.8.3.min.js", * function () { * whir.res.loadJs("turntable", "Script/whir.turntable.js", null); * });
    * 3.加载css,如:whir.res.loadCss("abc", "/Style/abc.css", null);
    */
    var whir = window.whir || {};
    whir.res
    = { pageVersion: "", //页面版本,由页面输出,用于刷新localStorage缓存

    //动态加载js文件并缓存

    loadJs: function (name, url, callback) {
    if (window.localStorage) {
    var xhr;
           
          // 存储 获取 
    var js = localStorage.getItem(name);
          
            // 如果版本有更新, 或者js没读出来, 就用ajax获取最新的
    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;
                     //创建一个link标签 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.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) {
    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 {
           //不支持ls, 只能重新获取 whir.res.linkCss(url); } },
    //往页面写入js脚本 writeJs: function (text) { var head = document.getElementsByTagName('HEAD').item(0); var link = document.createElement("script"); link.type = "text/javascript"; link.innerHTML = text; head.appendChild(link); }, //往页面写入css样式 writeCss: function (text) { var head = document.getElementsByTagName('HEAD').item(0); var link = document.createElement("style"); link.type = "text/css"; link.innerHTML = text; head.appendChild(link); }, //往页面引入js脚本 linkJs: function (url) { var head = document.getElementsByTagName('HEAD').item(0); var link = document.createElement("script"); link.type = "text/javascript"; link.src = url; head.appendChild(link); }, //往页面引入css样式 linkCss: function (url) { 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">  
        //入口函数  
        whir.res.pageVersion = "1002";  //页面版本,用于检测是否需要更新缓存  
        whir.res.loadJs("jquery", "/gfdzp201508257998/Turntable/Script/jquery-1.8.3.min.js",  
         function () {  
             whir.res.loadJs("turntable", "/gfdzp201508257998/Turntable/Script/whir.turntable.js", null);  
         });  
        whir.res.loadCss("css", "/gfdzp201508257998/Turntable/Style/css_whir.css", null);  
    </script>  
  • 相关阅读:
    UILabel 分段改变文字颜色和字体
    ios tableView删除行
    ios 控件点击没反应的问题
    ios MJRefresh最新的一些使用
    android下水波纹效果实现
    9patch的用法,简单两句就会用了。
    有关android.support.v7.app.ActionBarActivity错误的问题
    android中fragment的使用及与activity之间的通信
    [转]CSS中继承性属性和非继承性的属性
    js中的attribute详解
  • 原文地址:https://www.cnblogs.com/dhsz/p/6593108.html
Copyright © 2011-2022 走看看