asp.net-mvc – 使用像Stackoverflow这样的查询字符串版本化CSS文件?

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – 使用像Stackoverflow这样的查询字符串版本化CSS文件?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > What does ‘?’ do in a Css link?
如果你看看Stackoverflow.com的来源,你会看到他们的css文件的引用是:
<link href="/Content/all.min.css?v=2383" rel="stylesheet" type="text/css" />

这样做如何可以通过查询字符串传递一个版本,并提供正确的CSS文件

解决方法

This (PHP example)文章解释一下你背后的想法。基本上,您可以发现上次修改文件的时间戳。这样,每当您更改CSS时,查询字符串将会更改,“强制”浏览器下载新版本。这对于CSS和JS文件都是有效的。

ASP.NET示例是这样的:

public static string GetBreaker(string fileName)
{
    string cacheBreaker = null;
    try
    {
        if (fileName.StartsWith("~"))
        {
            fileName = Path.Combine(AppDomain.CurrentDomain.BaseDirectory,fileName.Remove(0));
        }
        cacheBreaker = File.GetLastWriteTime(fileName).ToFileTime().ToString();
    }
    catch { }

    return string.IsNullOrEmpty(cacheBreaker) ? string.Empty : string.Format("?cachebreaker={0}",cacheBreaker);
}

并且您以这种方式在您的MasterPage中调用方法

<link href="<%= this.ResolveClientUrl("~/CSS/style.css") %><%=CacheBreaker.GetBreaker("~/CSS/style.css") %>"
            rel="stylesheet" type="text/css" />

猜你在找的asp.Net相关文章