移动端使用localStorage缓存Js和css文的方法(web开发)

将jquery和公共样式缓存到localStorage,可以减少Http请求,从而优化页面加载时间,下面的代码可以实现此功能

rush:js;">

查看写入记录:

封装成JS插件

rush:js;"> /** * 插件功能:使用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("css","/Style/css_whir.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); 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",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.XMLHTTP"); } else if (window.XMLHttpRequest) { xhr = new XMLHttpRequest(); } if (xhr != null) { xhr.open("GET",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); } },//往页面写入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); } }

调用插件

rush:js;">

以上所述是小编给大家介绍的移动端使用localStorage缓存Js和css文的方法(web开发)。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...