Asp.net程序优化js、css实现合并与压缩的方法
2014-12-17 00:00
1161 查看
本文实例讲述了Asp.net程序优化js、css实现合并与压缩的方法。分享给大家供大家参考。具体实现方法如下:
访问时将js和css压缩并且缓存在客户端,
采用的是Yahoo.Yui.Compressor组件来完成的,用户可以点击此处本站下载。
创建一个IHttpHandler来处理文件
最后在配置文件中配置一下CombineFiles.axd文件,具体配置略
引用如下
希望本文所述对大家的asp.net程序设计有所帮助。
访问时将js和css压缩并且缓存在客户端,
采用的是Yahoo.Yui.Compressor组件来完成的,用户可以点击此处本站下载。
创建一个IHttpHandler来处理文件
public class CombineFiles : IHttpHandler { private const string CacheKeyFormat = "_CacheKey_{0}_"; private const bool IsCompress = true; //需要压缩 public bool IsReusable { get { return false; } } public void ProcessRequest(HttpContext context) { HttpRequest request = context.Request; HttpResponse response = context.Response; string cachekey = string.Empty; string type = request.QueryString["type"]; if (!string.IsNullOrEmpty(type) && (type == "css" || type == "js")) { if (type == "js") { response.ContentType = "text/javascript"; } else if (type == "css") { response.ContentType = "text/css"; } cachekey = string.Format(CacheKeyFormat, type); CompressCacheItem cacheItem = HttpRuntime.Cache[cachekey] as CompressCacheItem; if (cacheItem == null) { string content = string.Empty; string path = context.Server.MapPath(""); //找到这个目录下所有的js或css文件,当然也可以进行配置,需求请求压缩哪些文件 //这里就将所的有文件都请求压缩 string[] files = Directory.GetFiles(path, "*." + type); StringBuilder sb = new StringBuilder(); foreach (string fileName in files) { if (File.Exists(fileName)) { string readstr = File.ReadAllText(fileName, Encoding.UTF8); sb.Append(readstr); } } content = sb.ToString(); // 开始压缩文件 if (IsCompress) { if (type.Equals("js")) { content = JavaScriptCompressor.Compress(content); } else if (type.Equals("css")) { content = CssCompressor.Compress(content); } } //输入到客户端还可以进行Gzip压缩 ,这里就省略了 cacheItem = new CompressCacheItem() { Type = type, Content = content, Expires = DateTime.Now.AddDays(30) }; HttpRuntime.Cache.Insert(cachekey, cacheItem, null, cacheItem.Expires, TimeSpan.Zero); } string ifModifiedSince = request.Headers["If-Modified-Since"]; if (!string.IsNullOrEmpty(ifModifiedSince) && TimeSpan.FromTicks(cacheItem.Expires.Ticks - DateTime.Parse(ifModifiedSince).Ticks).Seconds < 0) { response.StatusCode = (int)System.Net.HttpStatusCode.NotModified; response.StatusDescription = "Not Modified"; } else { response.Write(cacheItem.Content); SetClientCaching(response, cacheItem.Expires); } } } private void SetClientCaching(HttpResponse response, DateTime expires) { response.Cache.SetETag(DateTime.Now.Ticks.ToString()); response.Cache.SetLastModified(DateTime.Now); //public 以指定响应能由客户端和共享(代理)缓存进行缓存。 response.Cache.SetCacheability(HttpCacheability.Public); //是允许文档在被视为陈旧之前存在的最长绝对时间。 response.Cache.SetMaxAge(TimeSpan.FromTicks(expires.Ticks)); response.Cache.SetSlidingExpiration(true); } private class CompressCacheItem { /// <summary> /// 类型 js 或 css /// </summary> public string Type { get; set; } // js css /// <summary> /// 内容 /// </summary> public string Content { set; get; } /// <summary> /// 过期时间 /// </summary> public DateTime Expires { set; get; } } }
最后在配置文件中配置一下CombineFiles.axd文件,具体配置略
引用如下
<script type="text/javascript" src="/js/CombineFiles.axd?type=js"></script> <link rel="stylesheet" type="text/css" href="/css/CombineFiles.axd?type=css" />
希望本文所述对大家的asp.net程序设计有所帮助。
相关文章推荐
- Asp.net程序优化js、css实现合并与压缩的方法
- Asp.net 程序优化js,css合并与压缩
- Asp.net 程序优化js,css合并与压缩
- ASP.NET下使用Combres对JS、CSS合并和压缩
- Asp.net MVC下使用Bundle合并、压缩js与css文件详解
- asp.net后台动态添加JS文件和css文件的引用实现方法
- ASP.NET MVC 4 Optimization的JS/CSS文件动态合并及压缩
- [Asp.net MVC]Bundle合并,压缩js、css文件
- ASP.NET下使用Combres对JS、CSS合并和优化
- web优化之-Asp.net MVC js、css动态合并 动态压缩
- ASP.NET MVC中使用Bundle打包压缩js和css的方法
- web优化之-Asp.net MVC js、css动态合并 动态压缩 (2)
- asp.net后台动态添加JS文件和css文件的引用实现方法
- ASP.Net一键自动化更新代码、编译、合并dll、压缩js、css、混淆dll、zip打包、发布到测试环境的bat批处理
- web优化之-Asp.net MVC js、css动态合并 动态压缩 (2)
- ASP.NET MVC中使用Bundle打包压缩js和css的方法
- Asp.net MVC WEB 优化之 - js、css动态合并 动态压缩
- web优化之-Asp.net MVC js、css动态合并 动态压缩
- 在ASP.Net中两种利用CSS实现多界面的方法
- 在ASP.Net中两种利用CSS实现多界面的方法.