国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 服務器 > Web服務器 > 正文

關于web開發中產生的瀏覽器緩存問題的解決方法

2024-09-01 13:28:16
字體:
來源:轉載
供稿:網友
  1、問題背景
 
  在做web開發中,經常遇到這樣的問題:已經修改完css樣式或者js代碼,F5刷新瀏覽器,發現剛修改完的代碼并沒有生效,這個大家都知道是緩存造成的,瀏覽器這樣設計的目的也是為了節省用戶流量,因為資源文件一般較穩定,數量多,但修改量少。下面來說說五種解決方法,以及各自的優缺點。
 
  2、解決方法
 
  方法一
 
  簡單粗暴的同時按住ctrl-shift-delete三個鍵來調出“清除瀏覽數據”功能,效果如下圖(不同瀏覽器大同小異),主要勾選上緩存的圖片和文件,清除數據即可,然后刷新,該種方法并不推薦,因為真正的用戶都是小白,資源文件發生更新應該讓用戶無感知的獲得最新資源,并且每次清除瀏覽數據,你訪問過的其他網站的資源也被清空了。不推薦。
 
  
 
  方法二:使用ctrl+F5強制刷新當前網站,問題同方法一,略優于方法一,該方法單獨強刷當前網站。不推薦。
 
  方法三:jsp代碼中引用js或css文件時在引用路徑后面添加一個參數(隨機數或者當前時間),示例如下:
 
  <scripttype="text/javascript"src="/js/yourjs.js?rd=<%=Math.random()%>"></script>
 
  這樣在你每次按F5時候,src發生改變,瀏覽器會重新請求js文件。壞處是這樣每次用戶刷新頁面都會重新下載資源文件,即使你根本沒有去修改資源文件,好處是這樣處理十分方便。不十分推薦。
 
  方法四:所有jsp引用相同的taglib,并在公用的jsp中設置一個版本號,并在css或js路徑中進行引用,每次發布新版本時候,根據需要來修改版本號。如果資源文件有更新,發布時修改下版本號即可,如果沒有更新則不用修改版本號,這樣極具可控性。推薦該方法。
 
  操作如下:
 
  1)所有jsp中均引入taglib.jsp
 
  <%@includefile="/WEB-INF/common/taglib.jsp"%>
 
  2)taglib.jsp中設置一個版本號
 
  //<%@taglib......%>
 
  //該處一般為一些公用的taglib,如c,fn等
 
  //<%@taglib......%>
 
  <c:setvar="ctx"value="${pageContext.request.contextPath}"/>
 
  <c:setvar="version"value="20170906"/>
 
  3)jsp中引用資源時人為添加一個版本號
 
  <linkrel="stylesheet"type="text/css"href="${ctx}/static/css/your.css?v=${version}">
 
  <scriptsrc="${ctx}/static/js/your.js?v=${version}"></script>
 
  如上操作后每次在修改version的值后,發布到生產,用戶訪問時,由于src或者href中的v參數發生改變,瀏覽器就會重新去下載資源文件。
 
  注意:參數名v是隨意取的,沒有特別要求
 
  方法五:將瀏覽器設置為不緩存或使用插件設置為不緩存,這種方法也只是方便開發者,對用戶并無益處。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 天柱县| 浠水县| 舒城县| 北票市| 延边| 东乌珠穆沁旗| 准格尔旗| 长海县| 高台县| 桦川县| 精河县| 西平县| 武威市| 永善县| 双柏县| 昌黎县| 霍城县| 湘潭市| 廉江市| 江都市| 井陉县| 日照市| 万荣县| 驻马店市| 湘西| 金昌市| 沭阳县| 顺昌县| 会同县| 玛曲县| 梅州市| 肇州县| 东阿县| 侯马市| 华蓥市| 连江县| 惠水县| 西乌珠穆沁旗| 富平县| 汉沽区| 喀喇沁旗|