怎樣獲取最新版的javascript文件,解決被瀏覽器緩存的問題

来源:https://www.cnblogs.com/html5study-1/archive/2019/11/30/11962171.html
-Advertisement-
Play Games

轉載自:https://www.cnblogs.com/mafengzi/p/10464910.html 假設有一個js文件(以jquery為例),在伺服器上的URL地址為:../js/jquery.js 。 當某天jquery版本更新了,用最新版的jquery文件覆蓋了原來舊版的jquery文件。 ...


轉載自:https://www.cnblogs.com/mafengzi/p/10464910.html

假設有一個js文件(以jquery為例),在伺服器上的URL地址為:../js/jquery.js 。

當某天jquery版本更新了,用最新版的jquery文件覆蓋了原來舊版的jquery文件。

這時,在打開引用了此js文件的網頁時,有可能引用的還是舊版,這是因為瀏覽器有緩存,它緩存了舊版的jquery文件。

瀏覽器緩存文件是以完整的URL來緩存的,也就是說,當瀏覽器遇到一個與之前完全一致的URL請求時,就有可能使用之前緩存下來的文件,而不是向伺服器去請求文件。當然,緩存是有時效的,超過了一定的時間後,緩存將會消失。

既然是以完整的URL來緩存文件的,那麼我們就可以使用不同的文件名來訪問更新後的文件。

一種解決方法是,將版本號寫在文件名里,比如,可將以上的jquery.js的文件名改為 jquery-3.3.0.js,其中,3.3.0就是jquery的版本號。在前端引用時,就這樣寫:

<script src="../js/jquery-3.3.0.js"></script>

當某天jquery的版本更新為3.3.1了,我們就將文件名修改為jquery-3.3.1。前端引用的代號同時修改為:

<script src="../js/jquery-3.3.1.js"></script>

另一種解決方法是,不修改文件名,而是將版本號放在URL的query參數里,比如這樣寫:

<script src="../js/jquery.js?ver=3.3.0"></script>

其中ver=3.3.0就是版本號。當jquery的版本號更新為3.3.1之後,就改寫為這樣:

<script src="../js/jquery.js?ver=3.3.1"></script>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 概述&背景 MySQL一直被人詬病沒有實現HashJoin,最新發佈的8.0.18已經帶上了這個功能,令人欣喜。有時候在想,MySQL為什麼一直不支持HashJoin呢?我想可能是因為MySQL多用於簡單的OLTP場景,並且在互聯網應用居多,需求沒那麼緊急。另一方面可能是因為以前完全靠社區,這種演進 ...
  • SQL:Structured Quety Language SQL SERVER是一個以客戶/伺服器(c/s)模式訪問、使用Transact-SQL語言的關係型資料庫管理子系統(RDBMS) DBMS :Database Management System資料庫管理系統 資料庫:程式用來存取數據的 ...
  • Responding to the Launch of Your App Initialize your app’s data structures, prepare your app to run, and respond to any launch-time requests from the ...
  • 一、完成了內容中的右邊的一部分。練習了三點:小盒子在大盒子中的位置,最好用大盒子的內邊距完成佈局,而不是用小盒子的外邊距來進行佈局;複習了ul,li的用法。 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>D ...
  • css背景樣式屬性介紹 背景樣式就是自定義 標簽的背景顏色或背景圖像。 背景屬性說明表 屬性名 | 屬性值|描述 | | background color | f00、red、rgb(255,0,0)|設置背景顏色。 background image |url(背景圖片路徑)|設置背景圖像。 bac ...
  • jQuery中的事件 在JavaScript中,常用的基礎事件有滑鼠事件、鍵盤事件、window事件、表單事件、事件綁定和處理函數的語法格式如下 語法q 事件名 = "函數名()"; 或者 DOM對象.事件名 = 函數; 1、載入事件 $(function () {}); //推薦使用 $(docu ...
  • 簡單的小游戲製作,代碼量只有兩三百行。游戲可自行擴展延申。 源碼已發佈至github,喜歡的點個小星星,源碼入口: "game snake" 游戲已發佈,游戲入口: "http://snake.game.yanjd.top" 第一步 製作想法 游戲如何實現是首要想的,這裡我的想法如下: 1. 利用c ...
  • 在我們的日常前端開發中,使用最頻繁的莫過於使用 在瀏覽器的控制臺中列印出我們需要調試的信息,但是大部分人可能跟之前的我一樣,沒有意識到其實 除了 方法以外,還有很多實用的方法,這些方法可以使我們的調試過程更加容易,也表達得更加直觀,更加豐富多彩,下麵我們就來看看有哪些實用的方法吧! 1、consol ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...