博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
转:ASP.NET MVC4细嚼慢咽---(5)js css文件合并
阅读量:6252 次
发布时间:2019-06-22

本文共 3745 字,大约阅读时间需要 12 分钟。

原文:

MVC4增加了一些新功能,接下来,我们来研究下MVC4中的新增功能,我们在新建一个MVC4项目的时候,会发现在项目下多出了一个App_Start文件夹,文件夹下面有4个文件,BundleConfig.cs,FilterConfig.cs,RouteConfig.cs,WebApiConfig.cs,其中BundleConfig.cs文件就是我们这一节要讲的的文件。

           众所周知,浏览器在向服务器发送请求的时候,请求的文件连接数量是有限制的。使用BundleConfig可以将多个文件请求和并成一个请求,去除文件中的一些注释,空白,压缩文件的大小,自动合并压缩优化代码,缩短响应时间,提高网页速度,起到优化网站的作用。

         1.定义分组

           创建MVC4项目后,我们会在global.asax文件中的Application_Start()方法中看到如下代码,起到注册作用

            BundleConfig.RegisterBundles(BundleTable.Bundles);

            BundleConfig.cs代码

            

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

                  BundleCollection是一个集合,用于将绑定规则添加到集合中,使用Add方法.

                bundles.Add(new ScriptBundle("~/bundles/jquery").Include( "~/Scripts/jquery-{version}.js"));

                new ScriptBundle("~/bundles/jquery")定义一个分组名称,Include表示这个分组下具体包括的文件。

                version参数代表版本号 ,*代表所有,这两个是可以理解为通配符。

                 以上代码表示创建一个~/bundles/jquery分组,该分组指向的文件为scripts文件夹下的jquery-1.7.1.js文件。

                如果scripts文件夹下有jquery-1.7.1.js,jquery-1.6.1.js,则会指向这两个文件。

                        

              同样,bundles.Add(new StyleBundle("~/Content/css").Include("~/Content/site.css"));

              表示创建了一个~/Content/css分组,指向~/Content/site.css文件.

 

             2.使用分组

             分组已经定义好,我们接下演示怎样使用。

             如果在页面中使用scripts,可以使用@Scripts.Render("~/bundles/jquery")方法,参数为分组名称

             如果在页面中使用css,可以使用@Styles.Render("~/Content/css")方法,参数为分组名称.

             可以看下VIEWS文件夹下的Shard文件夹的_Layout.cshtml文件

            

[csharp] 
 
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4.     <meta charset="utf-8" />  
  5.     <meta name="viewport" content="width=device-width" />  
  6.     <title>@ViewBag.Title</title>  
  7.     @Styles.Render("~/Content/css")  
  8.     @Scripts.Render("~/bundles/modernizr")  
  9. </head>  
  10. <body>  
  11.     @RenderBody()  
  12.   
  13.     @Scripts.Render("~/bundles/jquery")  
  14.     @RenderSection("scripts", required: false)  
  15. </body>  
  16. </html>  

     运行项目后,可以查看页面源代码,效果如下

         

        

           3.合并请求

             接下来我们通过分组将请求多个文件合并成请求一个,可以使用如下两种方法来实现

               1.将web.config中的编译调试debug设为false  <compilation debug="false" targetFramework="4.5"/>

               2.在BundleConfig中的方法末尾添加  BundleTable.EnableOptimizations = true;

               再次运行页面,可以看到生成如下代码

                  src="/bundles/jquery?v=wBUqTIMTmGl9Hj0haQMeRbd8CoM3UaGnAwp4uDEKfnM1"

                  ?前面是分组名称,后面是多个文件合并后生成的哈希码

                   

            4.对比效果

              我们在火狐下用firebug查看合并前后的对比效果,可以对比下请求的文件大小,时间等方面的差别还是挺大的

                压缩合并前:

                  

             压缩合并后:

                

              注:默认情况下 BundleTable.Bundles会过滤掉后缀名为这些的文件,intellisense.js、-vsdoc.js、.debug.js、.min.js、.min.css,

                当加载后缀名为这些的文件,将显示空白。

                 可以用如下方法去除对这些文件过滤限制

 

               

[csharp] 
 
  1. BundleTable.Bundles.IgnoreList.Clear();   
  2.           BundleTable.Bundles.IgnoreList.Ignore(".min.js", OptimizationMode.Always);  
  3.           //BundleTable.Bundles.IgnoreList.Ignore("-vsdoc.js", OptimizationMode.Always);   
  4.           //BundleTable.Bundles.IgnoreList.Ignore(".debug.js", OptimizationMode.Always);   

 

 

 

                demo:下载:

转载于:https://www.cnblogs.com/ookami/p/3976518.html

你可能感兴趣的文章
BZOJ2064:分裂——题解
查看>>
poj 1797 Heavy Transportation(最短路径Dijkdtra)
查看>>
[转] 拉格朗日对偶
查看>>
WPF 在事件中绑定命令
查看>>
《工作DNA》读后感
查看>>
基于WinDbg的内存泄漏分析
查看>>
《小故事》
查看>>
气象预警采集及推送
查看>>
【SSH网上商城项目实战29】使用JsChart技术在后台显示商品销售报表
查看>>
python 基础复习 09 之基础函数
查看>>
Extjs 4
查看>>
教你使用Android SDK布局优化工具layoutopt
查看>>
Java内存模型(JMM)以及 垃圾回收机制 小结
查看>>
开源3D游戏引擎Irrlicht简介
查看>>
如何花更少的时间学习更多的知识
查看>>
学习鸟哥的Linux私房菜笔记(8)——文件查找与文件管理2
查看>>
day04 列表 增删改查 元组 range
查看>>
php 调用百度sms来发送短信的实现示例
查看>>
android 小结
查看>>
ThinkPHP5分页样式设置
查看>>