ASP.NET MVC学习笔记-----Bundles

在网页中,咱们常常须要引用大量的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")
相关文章
相关标签/搜索