Asp.Net使用Yahoo.Yui.Compressor.dll压缩Js|Css

go:http://www.cnblogs.com/stone_w/archive/2012/12/11/2812538.html

网上压缩css和js工具很多,但在我们的系统中总有特殊的地方。也许你会觉得用第三方的压缩工具很麻烦。我就遇到了这样问题,我不想在本地压缩,只想更新到服务器上去压缩,服务器压缩也不用备份之类的操作。于是我就想着自己实现压缩工具。

初步需求如下: 

  • 使用Yahoo.Yui.Compressor 2.0版本
  • 只对网站目录下指定文件夹中css和js进行压缩
  • 使用到了JQuery插件,所以有很多都是压缩过的js。所以对文件名称中保存min的不进行压缩
  • 不需要备份文件
  • 如在第一次访问文件时候进行压缩或应用程序启动时候进行压缩? 

实现(应用程序启动压缩版本): 

  • 引用 Yahoo.Yui.Compressor.dll
  • 在Global.asax的Application_Start事件中加入处理代码--code:
?
var files = System.IO.Directory.GetFiles(Server.MapPath( "~/" ), "*.*" , SearchOption.AllDirectories);
foreach  (var file in  files)
{
     FileInfo finfo = new  FileInfo(file);
     //todo 你可以在文件夹添加可以文件记录最后压缩时间.再判断文件最后修改时间是在上一次压缩时间之后的文件.而且这里还可以做异步处理
 
     string  strContent = File.ReadAllText(file, Encoding.UTF8);
     //名称不是min
     //todo 可能需要更完善的判断
     if  (!file.Contains( ".min." ))
     {
         //取消文件只读
         File.SetAttributes(file, FileAttributes.Normal);
         if  (finfo.Extension.ToLower() == ".js" )
         {
             //初始化JS压缩类
             var js = new  JavaScriptCompressor();
             js.CompressionType = CompressionType.Standard; //压缩类型
             js.Encoding = Encoding.UTF8; //编码
             js.IgnoreEval = false ; //大小写转换
             js.ThreadCulture = System.Globalization.CultureInfo.CurrentCulture;
             //压缩该js
             strContent = js.Compress(strContent);
 
             File.WriteAllText(file, strContent, Encoding.UTF8);
         }
         else  if  (finfo.Extension.ToLower()== ".css" )
         {
             //进行CSS压缩
             CssCompressor css = new  CssCompressor();
             strContent = css.Compress(strContent);
             File.WriteAllText(file, strContent, Encoding.UTF8);
         }
     }
}

 

完整代码下载:http://files.cnblogs.com/xuchengzone/JS-CSS.Compressor.rar

 


作者:西安.王磊 
出处:http://stone_w.cnblogs.com/ 
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 

标签:  jsasp.netc#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值