在网页中,咱们常常须要引用大量的javascript和css文件,在加上许多javascript库都包含debug版和通过压缩的release版(好比jquery),不只麻烦还很容易引发混乱,因此ASP.NET MVC4引入了Bundles特性,使得咱们能够方便的管理javascript和css文件。javascript
原来,咱们引用css和javascript文件咱们须要这样一个一个的引用:css
<script src="~/Scripts/jquery-1.8.2.js"></script> <script src="~/Scripts/jquery-ui-1.8.24.js"></script> <script src="~/Scripts/jquery.validate.js"></script> <link href="~/Content/Site.css" rel="stylesheet" />
当须要引用文件的数量较少时还好,但一旦每一个页面都须要引用较多文件时,会形成极大的不便,当咱们想更换某个引用文件时,将会浪费大量的时间。发布时,还要将一些库替换成release版,好比上面的jquery-1.8.2.js所对应的jquery-1.8.2.min.jsjava
还好,如今咱们能够使用Bundles特性:jquery
public class BundleConfig { 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*")); bundles.Add(new StyleBundle("~/Content/css").Include("~/Content/site.css")); } }
接着在Global.asax文件的Application_Start方法中调用BundleConfig.RegisterBundles方法:函数
protected void Application_Start() { AreaRegistration.RegisterAllAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); }
在上面咱们能够看到咱们按照功能的不一样,将不一样的文件分到了相应的Bundle(Bundle就是包的意思),其中构造函数中的string参数是Bundle的名称,Include函数是将参数相应的文件包含成一个Bundle。能够发现,对于jquery库咱们使用了这样的名称~/Scripts/jquery-{version}.js,其中{version}部分表明版本号的意思,MVC将会替咱们在Scripts文件中寻找对应的"jquery-版本号.js"文件,而且在非debug模式下,MVC则会使用“jquery-版本号.min.js"文件。ui
咱们还看到咱们使用了这样的名称~/Scripts/jquery.validate*的名称,*是一个通配符,这就意味着Scripts文件夹下的全部前缀为jquery.validate的文件都将包含在同一个Bundle中。spa
最后,咱们能够View上使用Bundle来代替原来引用的方式:debug
@Styles.Render("~/Content/css") @Scripts.Render("~/bundles/jquery")