首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Asp.Net使用Yahoo.Yui.Compressor.dll压缩Js|Css

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

作者头像
磊哥
发布2018-05-08 15:54:58
2.1K0
发布2018-05-08 15:54:58
举报
文章被收录于专栏:王磊的博客王磊的博客

网上压缩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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2012-12-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档