热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

html防替换资源,html前端进行资源重载及刷新资源

最近开发webview嵌套开发,遇到资源重载的问题,具体表现在:css缓存强硬,js缓存强硬,无法事实更新静态

最近开发webview嵌套开发,遇到资源重载的问题,具体表现在:css缓存强硬,js缓存强硬,无法事实更新静态资源,但若是禁止页面使用缓存策略的话,对服务器的占用比就会提高,访问少的时候,还好,访问量几何上升时,服务器就GG了。

经过多方查找发现除去glup,webpack,node,以及服务器做资源版本之外,并没有一个简单省事的方法,但项目时单纯的html页面,并没有什么框架使用,如若使用打包方式增加版本号更新缓存的话,相比较会麻烦一些,所以自己扣置了个小玩意。

由于script标签更新src之后并不会资源重载,所以使用了标签重新插入,link标签在更新href之后,资源会重新进行加载,所以直接替换路径

废话不多说,直接上代码:

function EditionFn (edition){

if(edition.notUrl){

edition.notUrl = edition.notUrl.split(",")

}else{

edition.notUrl = ["///"]

}

edition.notHtml = edition.notHtml || "///";

edition.isHtml = edition.isHtml || location.pathname;

if(location.pathname.indexOf(edition.notHtml) > -1 && location.pathname.indexOf(edition.isHtml) <0){

return false

}

var COOKIE &#61; document.COOKIE

COOKIE &#61; COOKIE.split(";")

COOKIE.forEach(function(item){

item &#61; item.replace(/\s*/g, "")

var thistime &#61; item.split("&#61;");

COOKIE[thistime[0]]&#61; thistime[1]

})

function loadJS(script){

var src &#61; script;

var script_dom &#61; document.createElement(&#39;script&#39;);

script_dom.src &#61; src;

script_dom.language &#61; &#39;Javascript&#39;;

script_dom.type &#61; &#39;text/Javascript&#39;;

var head &#61; document.getElementsByTagName(&#39;head&#39;).item(0);

head.appendChild(script_dom);

}

var scrUrl &#61; [];

$(&#39;script&#39;).each(function(){

if($(this).attr("charset") &#61;&#61; "utf-8" && $(this).attr("src") && COOKIE.edition && COOKIE.edition !&#61; edition.edition){

var src &#61; $(this).attr("src")&#43; &#39;?v&#61;&#39; &#43; edition.edition;

scrUrl.push(src)

$(this).attr("src","");

}

})

if(scrUrl.length > 0){

scrUrl.forEach(function(item){

var thisType &#61; true;

edition.notUrl.forEach(function(items){

if(item.indexOf(items) > -1){

thisType &#61; false;

}

})

if(thisType){

loadJS(item)

}

})

}

$(&#39;link&#39;).each(function(){

if($(this).attr("type") &#61;&#61; "text/css" && $(this).attr("href") && COOKIE.edition && COOKIE.edition !&#61; edition.edition){

var src &#61; $(this).attr("href")&#43; &#39;?v&#61;&#39; &#43; edition.edition;

var thisType &#61; true;

edition.notUrl.forEach(function(items){

if(src.indexOf(items) > -1){

thisType &#61; false;

}

})

if(thisType){

$(this).attr("href",src)

}

}

})

var times &#61; new Date().getTime() &#43; 7*24*60*60*1000;

if(COOKIE.edition && COOKIE.edition !&#61; edition.edition){

document.COOKIE &#61; "edition&#61;"&#43;edition.edition&#43;"; expires&#61;"&#43;new Date(times)&#43;";" ;

}else{

document.COOKIE &#61; "edition&#61;"&#43;edition.edition&#43;"; expires&#61;"&#43;new Date(times)&#43;";";

}

}

调用如下&#xff1a;

EditionFn({

edition:edition,

notUrl:"base64.js",

notHtml: &#39;///&#39;,

isHtml: "cssAndjsSession"

})

代表参数如下&#xff1a;

edition: 版本号

notUrl&#xff1a;不重载更新资源&#xff0c;默认为空

notHtml&#xff1a;不重载更新路径&#xff0c;默认为空

isHtml&#xff1a;重载更新指定页面(目前只能指定单个页面&#xff0c;要想多个页面自己去改代码吧)&#xff0c;默认所有页面都会更新

第一次请求时&#xff0c;不会资源重载&#xff0c;只有版本号不符时&#xff0c;会进行资源重载

欢迎各位指教一二



推荐阅读
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
author-avatar
醒来时t我尚年少你未老
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有