浏览器出于性能考虑,对js/css一类的静态资源,并不是每次都向服务器询问此资源是否有更新,各位一定都有这样的经历:明明服务器上的脚本更新了,但抓包发现浏览器根本没有发请求询问,直接就使用了本地的缓存,结果导致蹦了脚本错误提示,非要F5甚至Ctrl+F5强制刷新一下才好。
页面我们可以强制浏览器不缓存,但资源不受我们控制,目前可行的方法就是加后缀,每次资源有更新时就变换这个后缀,让浏览器认为它是新资源。比如用版本号做后缀,这样:
- <script type="text/javascript" src="../scripts/core.js"></script>
- 改为
- <script type="text/javascript" src="../scripts/core.js?115"></script>
不过缺点也是显而易见的,维护起来太麻烦了,很容易漏,除非你有合适的发布工具来干这件事。
换一个方法,用资源的最后更新时间做后缀,只要写一个公共方法就好了,以ASP.Net为例:
- <script type="text/javascript" src="<%= UI.Get("../scripts/core.js") %>"></script>
- using System;
- using System.IO;
- using System.Web;
- namespace Test.WebUI
- {
- public class UI
- {
- public static string Get(string url)
- {
- return string.Format("{0}?{1}", url, File.GetLastWriteTime(HttpContext.Current.Server.MapPath(url)).Ticks);
- }
- }
- }
这下终于解脱了。
本文转自 BoyTNT 51CTO博客,原文链接:http://blog.51cto.com/boytnt/1114397,如需转载请自行联系原作者