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

移动端webapp值得一试:
  • 兼容性好
  • 网速慢,LS读取+eval大多数情况下快于304
  • webapp不需要seo,css也可以缓存,再通过js加载
  • 浏览器缓存经常会被清理,LS被清理的几率低一些
  1. /**
  2. * 插件功能:使用localStorage缓存js和css文件,减少http请求和页面渲染时间,适用于Web移动端H5页面制作。
  3. * 插件作者:zhangqs008@163.com
  4. * 使用方法:
  5. * 1.使用此插件前,需要给插件的pageVersion变量赋值,建议变量值由服务器后端输出,当需要更新客户端资源时,修改版本值即可。
  6. * 2.加载Js:由于js加载有顺序要求,所以需要将后加载的脚本作为前一个脚本的回调参数传入,如:
  7. * whir.res.loadJs("jquery", "<%= BasePath %>Turntable/Script/jquery-1.8.3.min.js",
  8. * function () {
  9. * whir.res.loadJs("turntable", "Script/whir.turntable.js", null);
  10. * });
  11. * 3.加载css,如:whir.res.loadCss("abc", "/Style/abc.css", null);
  12. */
  13. var whir = window.whir || {};
  14. whir.res = {
  15. pageVersion: "", //页面版本,由页面输出,用于刷新localStorage缓存
  16.  
  17. //动态加载js文件并缓存
  18.  
  19. loadJs: function (name, url, callback) {
  20. if (window.localStorage) {
  21. var xhr;
           
          // 存储 获取 
  22. var js = localStorage.getItem(name);
          
            // 如果版本有更新, 或者js没读出来, 就用ajax获取最新的
  23. if (js == null || js.length == 0 || this.pageVersion != localStorage.getItem("version")) {
  24. if (window.ActiveXObject) {
  25. xhr = new ActiveXObject("Microsoft.XMLHTTP");
  26. } else if (window.XMLHttpRequest) {
  27. xhr = new XMLHttpRequest();
  28. }
  29. if (xhr != null) {
  30. xhr.open("GET", url);
  31. xhr.send(null);
  32. xhr.onreadystatechange = function () {
  33. if (xhr.readyState == 4 && xhr.status == 200) {
  34. js = xhr.responseText;
  35.  
  36.                 //储存 更新
  37. localStorage.setItem(name, js);
  38. localStorage.setItem("version", whir.res.pageVersion);

  39. js = js == null ? "" : js;
                     //创建一个link标签
  40. whir.res.writeJs(js);
  41. if (callback != null) {
  42. callback(); //回调,执行下一个引用
  43. }
  44. }
  45. };
  46. }
  47. } else {
  48. whir.res.writeJs(js);
  49. if (callback != null) {
  50. callback(); //回调,执行下一个引用
  51. }
  52. }
  53. } else {
  54. whir.res.linkJs(url);
  55. }
  56. },
  57. loadCss: function (name, url) {
  58. if (window.localStorage) {
  59. var xhr;
  60. var css = localStorage.getItem(name);
  61. if (css == null || css.length == 0 || this.pageVersion != localStorage.getItem("version")) {
  62.  
  63.           if (window.ActiveXObject) {
  64. xhr = new ActiveXObject("Microsoft.XMLHTTP");
  65. } else if (window.XMLHttpRequest) {
  66. xhr = new XMLHttpRequest();
  67. }
  68. if (xhr != null) {
  69. xhr.open("GET", url);
  70. xhr.send(null);
  71. xhr.onreadystatechange = function () {
  72. if (xhr.readyState == 4 && xhr.status == 200) {
  73. css = xhr.responseText;
  74. localStorage.setItem(name, css);
  75. localStorage.setItem("version", whir.res.pageVersion);
  76. css = css == null ? "" : css;
  77. css = css.replace(/images\//g, "style/images/"); //css里的图片路径需单独处理

  78.                  whir.res.writeCss(css);
  79. }
  80. };
  81. }
  82. } else {
  83. css = css.replace(/images\//g, "style/images/"); //css里的图片路径需单独处理
  84. whir.res.writeCss(css);
  85. }
  86. } else {
           //不支持ls, 只能重新获取
  87. whir.res.linkCss(url);
  88. }
  89. },
  90. //往页面写入js脚本
  91. writeJs: function (text) {
  92. var head = document.getElementsByTagName('HEAD').item(0);
  93. var link = document.createElement("script");
  94. link.type = "text/javascript";
  95. link.innerHTML = text;
  96. head.appendChild(link);
  97. },
  98. //往页面写入css样式
  99. writeCss: function (text) {
  100. var head = document.getElementsByTagName('HEAD').item(0);
  101. var link = document.createElement("style");
  102. link.type = "text/css";
  103. link.innerHTML = text;
  104. head.appendChild(link);
  105. },
  106. //往页面引入js脚本
  107. linkJs: function (url) {
  108. var head = document.getElementsByTagName('HEAD').item(0);
  109. var link = document.createElement("script");
  110. link.type = "text/javascript";
  111. link.src = url;
  112. head.appendChild(link);
  113. },
  114. //往页面引入css样式
  115. linkCss: function (url) {
  116. var head = document.getElementsByTagName('HEAD').item(0);
  117. var link = document.createElement("link");
  118. link.type = "text/css";
  119. link.rel = "stylesheet";
  120. link.rev = "stylesheet";
  121. link.media = "screen";
  122. link.href = url;
  123. head.appendChild(link);
  124. }
  125. }
  1. <script type="text/javascript">
  2. //入口函数
  3. whir.res.pageVersion = "1002"; //页面版本,用于检测是否需要更新缓存
  4. whir.res.loadJs("jquery", "/gfdzp201508257998/Turntable/Script/jquery-1.8.3.min.js",
  5. function () {
  6. whir.res.loadJs("turntable", "/gfdzp201508257998/Turntable/Script/whir.turntable.js", null);
  7. });
  8. whir.res.loadCss("css", "/gfdzp201508257998/Turntable/Style/css_whir.css", null);
  9. </script>

利用 localStorage 储存css js的更多相关文章

  1. 利用IIS部署WEB网站以及解决CSS/JS不能显示问题

    利用IIS部署WEB网站以及解决CSS/JS不能显示问题 转载声明:http://blog.sina.com.cn/s/blog_a001e5980101b4kt.html vs中正常IIS发布网站后 ...

  2. 利用beautifulsoup下载网页html代码中的css, js, img文件并保存

    # -*- coding:utf-8 -*- from bs4 import BeautifulSoup as BS import urllib.request as rqst import os u ...

  3. css+js+html基础知识总结

    css+js+html基础知识总结 一.CSS相关 1.css的盒子模型:IE盒子模型.标准W3C盒子模型: 2.CSS优先级机制: 选择器的优先权:!important>style(内联样式) ...

  4. 前端工程师面试问题归纳(一、问答类html/css/js基础)

    一.参考资源 1.前端面试题及答案整理(一) 2.2017年前端面试题整理汇总100题 3.2018最新Web前端经典面试试题及答案 4.[javascript常见面试题]常见前端面试题及答案 5.W ...

  5. Gulp:静态资源(css,js)版本控制

    为了防止客户端的静态资源缓存,我们需要每次更新css或js的时候,通过md5或时间戳等方式重新命名静态资源: 然后涉及到的html模板里的src也要做相应的修改,静态资源需要优化(压缩合并) 文件目录 ...

  6. 认识大前端html+css+js

    认识大前端:前端就是将效果图生成网页,利用html+css+js等技术. 如果把前端比作一台汽车,那么html就是车的骨架,css就是完整的车的模型,而js就充当着车的发动机... 建议:   刚刚开 ...

  7. C# 封装miniblink 使用HTML/CSS/JS来构建.Net 应用程序界面和简易浏览器

    MiniBlink的作者是 龙泉寺扫地僧 miniblink是什么?   (抄了一下 龙泉寺扫地僧 写的简洁) Miniblink是一个全新的.追求极致小巧的浏览器内核项目,其基于chromium最新 ...

  8. 利用localStorage事件来跨标签页共享sessionStorage

    //干货 利用localStorage事件来跨标签页共享sessionStorage //因为cookie保存字节数量有限,很多童鞋考虑用html5 storage来保存临时数据,Sessionsto ...

  9. HTML/CSS/JS编码规范

    最近整理了一份HTML/CSS/JS编码规范,供大家参考.目录:一.HTML编码规范二.CSS编码规范三.JS编码规范 一.HTML编码规范 1. img标签要写alt属性 根据W3C标准,img标签 ...

随机推荐

  1. Python3.6写socket程序

    Python进行Socket程序编写使用的主要模块就是 socket 模块,在这个模块中可以找到 socket()函数,该函数用于创建套接字对象.套接字也有自己的方法集,这些方法可以实现基于套接字的网 ...

  2. oracle external密码验证

    什么是external密码验证 当OS user 中存在和DB user 同名的用户时   直接使用和DB user 同名的OS user 可以不输入密码直接登录数据库, [oracle@zxrac1 ...

  3. Python(名称空间、函数嵌套、函数对象)

    一.名称空间: 名称空间 定义:存放名字和值的绑定关系       内置名称空间 python自带的名字,如print.int.str 解释器启动就会生效   全局名称空间 文件级别定义的名字,都会放 ...

  4. Top 10 Uses For A Message Queue

    We’ve been working with, building, and evangelising message queues for the last year, and it’s no se ...

  5. 【Github教程】史上最全github使用方法:github入门到精通(转自eoeandroid.com)

    本文来源:http://www.eoeandroid.com/thread-274556-1-1.html 另附经典教程网址 :http://wuyuans.com/2012/05/github-si ...

  6. [转]毕设- 深入HBase架构解析(二)

    深入HBase架构解析(二) 前言 这是<深入HBase架构解析(一)>的续,不多废话,继续.... HBase读的实现 通过前文的描述,我们知道在HBase写时,相同Cell(RowKe ...

  7. Spring boot + jdbc学习笔记

    pom.xml: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www. ...

  8. Spring_Bean 之间的关系

    beans-relation.xml <?xml version="1.0" encoding="UTF-8"?><beans xmlns=& ...

  9. 初涉Rx套餐 之RxBinding(让你的事件流程更清晰)

    转载请注明出处:王亟亟的大牛之路 最近下班回家都在WOW,周末就爆肝,感觉人都要GO DIE了,昨天下午看了看RxBinding相关的功能感觉还是蛮强大的,所提供的API也是相当丰富(基本Rx套餐都是 ...

  10. quartz(4)--quartz.properties文件

    Quartz有一个叫做quartz.properties的配置文件,它允许你修改框架运行时环境.缺省是使用Quartz.jar里面的quartz.properties文件.当然你应该创建一个quart ...