当前位置: 首页 > 编程笔记 >

Asp.net程序优化js、css实现合并与压缩的方法

夹谷星剑
2023-03-14
本文向大家介绍Asp.net程序优化js、css实现合并与压缩的方法,包括了Asp.net程序优化js、css实现合并与压缩的方法的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了Asp.net程序优化js、css实现合并与压缩的方法。分享给大家供大家参考。具体实现方法如下:

访问时将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程序设计有所帮助。

 类似资料:
  • 本文向大家介绍php实现压缩多个CSS与JS文件的方法,包括了php实现压缩多个CSS与JS文件的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php实现压缩多个CSS与JS文件的方法。分享给大家供大家参考。具体实现方法如下: 1. 压缩css 使用方法如下: 2. 压缩js,利用jsmin类: 本实例源自:http://code.google.com/p/minify/ 其中jsm

  • 本文向大家介绍使用grunt合并压缩js和css文件的方法,包括了使用grunt合并压缩js和css文件的方法的使用技巧和注意事项,需要的朋友参考一下 需要了解的知识: 1、nodejs的安装与命令行使用 2、nodejs安装应用 3、grunt的初步了解 本文已假定读者已经熟悉以上知识。 好,我们继续: 任务1:将src目录下的所有zepto及插件合并,并压缩。 目录结构: 一、js合并压缩 第

  • 本文向大家介绍asp.net C#实现解压缩文件的方法,包括了asp.net C#实现解压缩文件的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了asp.net C#实现解压缩文件的方法。一共给大家介绍了三段代码,一个是简单的解压缩单个zip文件,后一个可以解压批量的大量的但需要调用ICSharpCode.SharpZipLib.dll类了,最后一个比较实例可压缩也可以解压缩了分享给大

  • 本文向大家介绍JS 图片压缩原理与实现方法详解,包括了JS 图片压缩原理与实现方法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JS 图片压缩原理与实现方法。分享给大家供大家参考,具体如下: 前言 说起图片压缩,大家想到的或者平时用到的很多工具都可以实现,例如,客户端类的有图片压缩工具 PPDuck3, JS 实现类的有插件 compression.js ,亦或是在线处理类的 OSS

  • 问题内容: 我想添加某种库,maven插件或“某物”来组合和压缩我的javascript和css源文件。 但是,我认为使用Java做到这一点非常困难。Rails的人们已经解决了这个问题……它使用未连接/未压缩的文件进行开发,然后在生产过程中压缩所有内容。它可以轻松执行此操作,因为您无需更改html标头或类似的内容- 它适用于测试和生产。这或多或少是我想要的。它甚至存在于Java空间吗? 我想做的最

  • 本文向大家介绍Docker镜像压缩与优化操作,包括了Docker镜像压缩与优化操作的使用技巧和注意事项,需要的朋友参考一下 现如今docker如此受人追捧,主要是因为它的轻量化、可以快速部署以及资源的利用。但是一个docker images质量的好与坏,主要取决于Dockerfile编写的质量。同样功能的镜像,但是不同的Dockerfile build出来的镜像大小是不一样的,这是因为docker