ASP.NET MVC之Bundle压缩JS和CSS

简介:

介绍Bundle之前先引用《淘宝技术这十年》中一段话,对Web前端稍微有点常识的人都应该知道,浏览器下一步会加载页面中用到的CSS、JS(JavaScript)、图片等样式、脚本和资源文件。但是可能相对较少的人才会知道,你的浏览器在同一个域名下并发加载的资源数量是有限的,例如IE 6和IE 7是两个,IE 8是6个,chrome各版本不大一样,一般是4~6个。Bundle是ASP.NET 4.5中的一个新特性,可用来将js和css进行压缩(多个文件可以打包成一个文件,也可以说是合并多个文件),并且可以区分调试和非调试,在调试时不进行压缩,以原始方式显示出来,以方便查找问题。如果你新建一个有模板的MVC4项目,就可以直接使用了。

官方写法

新建完一个MVC4项目之后可以在APP_Start中的BundleConfig.cs看到这样的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
     public  class  BundleConfig
     {
         // 有关 Bundling 的详细信息,请访问 http://go.microsoft.com/fwlink/?LinkId=254725
         public  static  void  RegisterBundles(BundleCollection bundles)
         {
             bundles.Add( new  ScriptBundle( "~/bundles/jquery" ).Include(
                         "~/Scripts/jquery-{version}.js" ));
 
             bundles.Add( new  ScriptBundle( "~/bundles/jqueryui" ).Include(
                         "~/Scripts/jquery-ui-{version}.js" ));
 
             bundles.Add( new  ScriptBundle( "~/bundles/jqueryval" ).Include(
                         "~/Scripts/jquery.unobtrusive*" ,
                         "~/Scripts/jquery.validate*" ));
 
             // 使用 Modernizr 的开发版本进行开发和了解信息。然后,当你做好
             // 生产准备时,请使用 http://modernizr.com 上的生成工具来仅选择所需的测试。
             bundles.Add( new  ScriptBundle( "~/bundles/modernizr" ).Include(
                         "~/Scripts/modernizr-*" ));
 
             bundles.Add( new  StyleBundle( "~/Content/css" ).Include( "~/Content/site.css" ));
 
             bundles.Add( new  StyleBundle( "~/Content/themes/base/css" ).Include(
                         "~/Content/themes/base/jquery.ui.core.css" ,
                         "~/Content/themes/base/jquery.ui.resizable.css" ,
                         "~/Content/themes/base/jquery.ui.selectable.css" ,
                         "~/Content/themes/base/jquery.ui.accordion.css" ,
                         "~/Content/themes/base/jquery.ui.autocomplete.css" ,
                         "~/Content/themes/base/jquery.ui.button.css" ,
                         "~/Content/themes/base/jquery.ui.dialog.css" ,
                         "~/Content/themes/base/jquery.ui.slider.css" ,
                         "~/Content/themes/base/jquery.ui.tabs.css" ,
                         "~/Content/themes/base/jquery.ui.datepicker.css" ,
                         "~/Content/themes/base/jquery.ui.progressbar.css" ,
                         "~/Content/themes/base/jquery.ui.theme.css" ));           
         }
     }
}

  同时我们可以看一下Global.asax中看下注册的代码,如图:

以上是官方推荐的写法,下面可以个人实践一下个人使用的时候的情况。

个人实战

Bundle有两个子类,一个是ScriptBundle可以理解为合并JS,一个StyleBundle可以理解为合并CSS,这个时候可以在BundleConfig中添加几行代码,如下:

1
2
3
4
5
6
ScriptBundle myscript =  new  ScriptBundle( "~/FlyElephant/Script" );
       myscript.Include( "~/Scripts/jquery-1.7.1.js" "~/Scripts/bundle.test.js" );
       StyleBundle mystyle =  new  StyleBundle( "~/FlyElephant/Style" );
       mystyle.Include( "~/Content/site.css" );
       bundles.Add(myscript);
       bundles.Add(mystyle);  

 转到ScriptBundle中的定义发现传递的是virtualPath,也就是虚路径:

1
2
3
4
5
public  class  ScriptBundle : Bundle
{
     public  ScriptBundle(string virtualPath);
     public  ScriptBundle(string virtualPath, string cdnPath);
}

  然后新建一个控制器BundleTest和视图,引用以上代码:

1
2
3
4
5
6
@{
     ViewBag.Title =  "BundleTest" ;
}
     @Scripts .Render( "~/FlyElephant/Script" )
     @Styles .Render( "~/FlyElephant/Style" )
@Html .Raw( "<a href='http://www.cnblogs.com/xiaofeixiang/' style='font-size:20px'>博客地址</a>" )

这个时候我们就很容易理解之前ScriptBundle中的虚路径大概是个什么概念了,这个时候运行看下效果:

 

运行到这里发现和正常引用没有什么区别,这个时候只需要添加一行代码就可以实现压缩的效果,在Global.ascx中Application_Start添加如下代码:

1
BundleTable.EnableOptimizations =  true ;

重新运行一下,效果如下:

 

EnableOptimizations表示是否启用压缩,如果你在本地不需要调试,直接运行网站,也可以去Web.config中去配置一下Debug为false也可以达到以上效果,不过该这个很蛋疼,一般都是直接改EnableOptimizations,而且EnableOptimizations是高于Debug的设置的;

1
<span style= "font-family: 'Microsoft YaHei'; font-size: 14px;" ><img src= "https://images0.cnblogs.com/blog/485855/201412/180834238126452.png"  alt= "" ><br></span>

本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4170898.html,如需转载请自行联系原作者

相关文章
|
28天前
html+js+css实现的建筑方块立体数字时钟源码
html+js+css实现的建筑方块立体数字时钟源码
76 33
|
2月前
一个好看的小时钟html+js+css源码
一个好看的小时钟html+js+css源码
116 24
|
2月前
|
JavaScript 前端开发
页面滚动触发css3动画js插件
delighters.js是一款页面滚动触发css3动画js插件。该js插件可以在页面向下滚动时,为进入浏览器视口的元素制作各种炫酷的CSS3动画效果。
57 13
|
2月前
纸屑飘落生日蛋糕场景js+css3动画特效
纸屑飘落生日蛋糕CSS3动画特效是一款js+css3制作的全屏纸屑飘落,生日蛋糕点亮庆祝动画特效。
59 3
|
3月前
|
前端开发 JavaScript
用HTML CSS JS打造企业级官网 —— 源码直接可用
必看!用HTML+CSS+JS打造企业级官网-源码直接可用,文章代码仅用于学习,禁止用于商业
214 1
|
3月前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
72 3
|
3月前
JS+CSS3文章内容背景黑白切换源码
JS+CSS3文章内容背景黑白切换源码是一款基于JS+CSS3制作的简单网页文章文字内容背景颜色黑白切换效果。
33 0
|
6月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
83 0
|
9月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
244 0
|
9月前
|
开发框架 前端开发 JavaScript
JavaScript云LIS系统源码ASP.NET CORE 3.1 MVC + SQLserver + Redis医院实验室信息系统源码 医院云LIS系统源码
实验室信息系统(Laboratory Information System,缩写LIS)是一类用来处理实验室过程信息的软件,云LIS系统围绕临床,云LIS系统将与云HIS系统建立起高度的业务整合,以体现“以病人为中心”的设计理念,优化就诊流程,方便患者就医。
97 0

热门文章

最新文章