爲了強制加載,在文件名後加上類似於hash串的時間戳或者隨機數。
找了很久大佬們的解決方案,感覺下面這個最好用。
<script>document.write("<script type='text/javascript' src='//site.com
/js.js?v=" + Date.now() + "'><\/script>");</script>
簡潔,高效,數量任意,即插即用。
大佬還提供了個
<script type="text/javascript">
(function(){
var randomh=Math.random();
var e = document.getElementsByTagName("script")[0];
var d = document.createElement("script");
d.src = "//site.com/js.js?x="+randomh+"";
d.type = "text/javascript";
d.async = true;
d.defer = true;
e.parentNode.insertBefore(d,e);
})();
</script>
(然而這個不知道如何加載多個js。。)
緩存相關設置
強制不超過一天:
Cache-Control: max-age=86400, must-revalidate
永遠獲取最新文件:
Cache-Control: no-cache, must-revalidate
大佬↓:
https://stackoverflow.com/questions/11467873/how-to-append-timestamp-to-the-java-script-file-in-script-tag-url-to-avoid-cac