zoukankan      html  css  js  c++  java
  • asp.net mvc3 css/js压缩合并 combres

    NuGet   网站:http://nuget.codeplex.com/releases/view/64974

    Combres 英文介绍:http://www.codeproject.com/KB/aspnet/combres2.aspx

    mvc3的设置和使用过程,模板引擎是razor的。

    使用:

             (1)直接使用vs2010的 NuGet 功能

           (2)新建mvc3项目,打开vs2010,视图--->其他窗口--->Package Manager Console(需要系统程序包 Windows PowerShell 2.0,没有请安装)

           (3)输入 get-package -remote -filter  Combres.Mvc ,回车,显示如下:

    PM> get-package -remote -filter  Combres.Mvc Id                                                Version                                          Description                                     --                                                -------                                          -----------                                     combres.mvc                                       2.2.1.2                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.1.5                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.1.8                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.1.9                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.2.0                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.2.2                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.2.3                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.2.4                                          Include extension methods for Combres to inte... combres.mvc                                       2.2.2.5                                          Include extension methods for Combres to inte...

    可以看到comberes.mvc 的版本,这里我安装的是 2.2.2.0 版本 输入 install-package -id Combres.Mvc  -version 2.2.2.0 , 回车自动安装combres.mvc

           (4)安装完成,会自动生成App_Data/combres.xml,这个就是设置压缩/合并的文件配置。这个是我的配置

    1. <??> 
    2. <combrescombres ='urn:combres'> 
    3.    <resourceSetsurl="~/combres.axd"defaultDuration="30"  
    4.                                  defaultVersion="auto"  
    5.                                  defaultDebugEnabled="auto"> 
    6.      <resourceSetname="siteCss"type="css"> 
    7.        <resourcepath="~/styles/site.css"/> 
    8.        <resourcepath="~/styles/jquery-ui-1.7.2.custom.css"/> 
    9.      </resourceSet> 
    10.     <resourceSetname="siteJs"type="js"> 
    11.       <resourcepath="~/scripts/jquery-1.4.4.js"/> 
    12.       <resourcepath="~/scripts/jquery-ui-1.7.2.custom.min.js"/> 
    13.     </resourceSet> 
    14.   </resourceSets> 
    15. </combres>  
    • defaultDuration 默认缓存的时间,单位为天数
    • defaultVersion 合并后的资源版本,在你修改了资源文件后需要对版本进行修改,你可以指定auto或者手动设置一个版本号
    • defaultDebugEnabled 调试的模式,为true时那么资源文件不进行压缩,开发时可以设置成true,上线后设置成false

           具体添加压缩方法的配置节点,用于选择哪种方法对资源文件进行压缩

    1. <cssMinifiers> 
    2.    <minifiername="yui"type="Combres.Minifiers.YuiCssMinifier, Combres"> 
    3.      <paramname="CssCompressionType"type="string"value="StockYuiCompressor"/> 
    4.      <paramname="ColumnWidth"type="int"value="-1"/> 
    5.    </minifier> 
    6. </cssMinifiers> 
    7. <jsMinifiers> 
    8.    <minifiername="msajax"type="Combres.Minifiers.MSAjaxJSMinifier, Combres"  
    9.    binderType="Combres.Binders.SimpleObjectBinder, Combres"> 
    10.     <paramname="CollapseToLiteral"type="bool"value="true"/> 
    11.     <paramname="EvalsAreSafe"type="bool"value="true"/> 
    12.     <paramname="MacSafariQuirks"type="bool"value="true"/> 
    13.     <paramname="CatchAsLocal"type="bool"value="true"/> 
    14.     <paramname="LocalRenaming"type="string"value="CrunchAll"/> 
    15.     <paramname="OutputMode"type="string"value="SingleLine"/> 
    16.     <paramname="RemoveUnneededCode"type="bool"value="true"/> 
    17.     <paramname="StripDebugStatements"type="bool"value="true"/> 
    18.   </minifier> 
    19. </jsMinifiers> 

           要使用哪种压缩方法,在resourceSet或者在resource上添加相应的属性即可,配置后像下面这样:

    1. <??> 
    2.   <combrescombres ='urn:combres'> 
    3.     <cssMinifiers> 
    4.       <minifiername="yui"type="Combres.Minifiers.YuiCssMinifier, Combres"> 
    5.         <paramname="CssCompressionType"type="string"value="StockYuiCompressor"/> 
    6.         <paramname="ColumnWidth"type="int"value="-1"/> 
    7.       </minifier> 
    8.     </cssMinifiers> 
    9.     <jsMinifiers> 
    10.      <minifiername="msajax"type="Combres.Minifiers.MSAjaxJSMinifier, Combres"  
    11.      binderType="Combres.Binders.SimpleObjectBinder, Combres"> 
    12.       <paramname="CollapseToLiteral"type="bool"value="true"/> 
    13.       <paramname="EvalsAreSafe"type="bool"value="true"/> 
    14.        <paramname="MacSafariQuirks"type="bool"value="true"/> 
    15.        <paramname="CatchAsLocal"type="bool"value="true"/> 
    16.        <paramname="LocalRenaming"type="string"value="CrunchAll"/> 
    17.        <paramname="OutputMode"type="string"value="SingleLine"/> 
    18.        <paramname="RemoveUnneededCode"type="bool"value="true"/> 
    19.        <paramname="StripDebugStatements"type="bool"value="true"/> 
    20.      </minifier> 
    21.    </jsMinifiers> 
    22.    <resourceSetsurl="~/combres.axd"defaultDuration="30"  
    23.                                  defaultVersion="auto"  
    24.                                  defaultDebugEnabled="auto"> 
    25.      <resourceSetname="siteCss"type="css"minifierRef="yui"> 
    26.        <resourcepath="~/styles/site.css"/> 
    27.        <resourcepath="~/styles/jquery-ui-1.7.2.custom.css"/> 
    28.      </resourceSet> 
    29.      <resourceSetname="siteJs"type="js"> 
    30.        <resourcepath="~/scripts/jquery-1.4.4.js"minifierRef="msajax"  /> 
    31.        <resourcepath="~/scripts/jquery-ui-1.7.2.custom.min.js"minifierRef="off"/> 
    32.      </resourceSet> 
    33.    </resourceSets> 
    34. </combres> 

    (5)删除 AppStart/Combres.cs,移除WebActivetor的引用。

    (6)打开 global.asax 添加 using Combres;的引用。在 RegisterRoutes 第一行添加

    1. routes.AddCombresRoute("Combres");  
    (7)在需要的页面上添加:
    1. @using Combres.Mvc;   
    2. <!DOCTYPE html>   
    3. <html>   
    4. <head>   
    5.     <meta charset="utf-8" />   
    6.     <title>@ViewBag.Title</title>   
    7.     @Html.CombresLink("siteCss")   
    8.     @Html.CombresLink("siteBaseCss")   
  • 相关阅读:
    SpringBoot标准化搭建
    springboot打开swagger文档遇到For input string: ""的报错 swagger版本2.9.2
    MySQL和Redis如何保证数据一致性? 三种方案对比,初版
    [转]QUdpSocket收发信息
    [原][C++][插件]window下C++简单插件机制实现
    php saas 架构设计,SaaS的几种架构解析
    如何处理将HTML打印出来中的断行,分页,修改打印内容等问题?急,谢谢!!
    批量打印 | 多页打印 | PHP多页打印
    web页面的单页打印以及批量打印实现方法
    php批量打印发票三(php用FPDF合并所有图片为PDF文档)
  • 原文地址:https://www.cnblogs.com/zxktxj/p/2526246.html
Copyright © 2011-2022 走看看