Asp.Net MVC4 BundleConfig文件合并、压缩,网站优化加速

浏览器在向服务器发送请求的时候,请求的文件链接数量是有限制的,如果页面文件少就没有什么问题了,如果文件太多就会导致链接失败等等问题。针对这个问题MVC4中增加了新功能:BundleConfig.cs,使用BundleConfig可以将多个文件请求和并成一个请求,去除文件中的一些注释、空白、压缩文件的大小,自动合并压缩优化代码,缩短响应时间,提高网页速度,起到优化网站的作用。

具体使用方法

1、注册BundleConfig

在global.asax文件中的Application_Start()方法中添加以下代码

1
 BundleConfig.RegisterBundles(BundleTable.Bundles);

2、创建分组文件

打开:App_Start/BundleConfig.cs 文件,里面有些系统默认的方法(如果是自己创建的文件是没有的,可以通过创建一个非空的MVC项目来查看)

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
39
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"));  
   
                     //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-*"));  
   
                    //CSS文件
           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"));  
       }  
   }

代码解释:

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

"~/bundles/jquery" :表示分组的文件路径(也就是产生一个虚拟的文件夹)。

"~/Scripts/jquery-{version}.js" :表示该分组包含的具体文件,是项目实际存在的文件。如果有多个文件参考代码中下面的写法。 {version}参数代表版本号 ,*代表所有,这两个是可以理解为通配符。

代码中的其它几个add意思是一样的。根据不同的文件类型等创建不同的分组,比如js文件创建一个分组,css创建一个分组等。

3、使用分组

在视图页面添加代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8" />  
    <meta name="viewport" content="width=device-width" />  
    <title>@ViewBag.Title</title>  
     
     <!--Style 分组代码调用  名称就是定义的分组文件名称 -->
    @Styles.Render("~/Content/css")  
     
     <!--JavaScript 分组代码调用  名称就是定义的分组文件名称 -->
    @Scripts.Render("~/bundles/modernizr")  
</head>  
<body>  
    @RenderBody() 
      
    <!--JavaScript 分组代码调用  名称就是定义的分组文件名称 -->
    @Scripts.Render("~/bundles/jquery")  
     
    @RenderSection("scripts", required: false)  
</body>  
</html>

代码解释:

1
@Scripts.Render("~/bundles/jquery")

其中的“~/bundles/jquery” 是上面定义的文件分组名称

4、合并页面请求

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

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

  2. 在BundleConfig中的方法末尾添加  BundleTable.EnableOptimizations = true; (建议使用这个方法),

配置完成以后刷新页面,就可以看到 :

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

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

可以要通过火狐的firebug或者是谷歌浏览器查看合并前后的效果,看着加载文件数量和加载速度还是有很大提升的。

5、其它注意事项

1、使用中注意区分Js和css文件,产生分组的方法和前台调用的方法名称都是不一样的,详细请看上面的代码

2、默认情况下BundleTable.Bundles会过滤掉后缀名为这些的文件:

,intellisense.js、-vsdoc.js、.debug.js、.min.js、.min.css,

当加载后缀名为这些的文件,将显示空白。可以用如下方法去除对这些文件过滤限制

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

如果提示:未能加载 WebGrease.dll ,请查看这里:http://ityouzi.com/archives/mvc-webgrease-error.html

mvc bundle的介绍及使用 转载自 http://www.ityouzi.com/archives/mvc-bundleconfig.html的更多相关文章

  1. 转载 mvc:message-converters简单介绍 https://www.cnblogs.com/liaojie970/p/7736098.html

    mvc:message-converters简单介绍 说说@ResponseBody注解,很明显这个注解就是将方法的返回值作为reponse的body部分.我们进一步分析下这个过程涉及到的内容,首先就 ...

  2. ASP.NET Core MVC – Tag Helpers 介绍

    ASP.NET Core Tag Helpers系列目录,这是第一篇,共五篇: ASP.NET Core MVC – Tag Helpers 介绍 ASP.NET Core MVC – Caching ...

  3. windows server 证书的颁发与IIS证书的使用 Dapper入门使用,代替你的DbSQLhelper Asp.Net MVC中Action跳转(转载)

    windows server 证书的颁发与IIS证书的使用   最近工作业务要是用服务器证书验证,在这里记录下一. 1.添加服务器角色 [证书服务] 2.一路下一步直到证书服务安装完成; 3.选择圈选 ...

  4. easyui datagrid 禁止选中行 EF的增删改查(转载) C# 获取用户IP地址(转载) MVC EF 执行SQL语句(转载) 在EF中执行SQL语句(转载) EF中使用SQL语句或存储过程 .net MVC使用Session验证用户登录 PowerDesigner 参照完整性约束(转载)

    easyui datagrid 禁止选中行   没有找到可以直接禁止的属性,但是找到两个间接禁止的方式. 方式一: //onClickRow: function (rowIndex, rowData) ...

  5. MVC bundle(CSS或JS)

    无论是有asp还是asp.net,还是php做网站经验的都知道当我们需要css或者js文件的时候我们需要在<head></head>标签中间导入我们需要的js或者css文件的路 ...

  6. .NET Core实战项目之CMS 第十三章 开发篇-在MVC项目结构介绍及应用第三方UI

    作为后端开发的我来说,前端表示真心玩不转,你如果让我微调一个位置的样式的话还行,但是让我写一个很漂亮的后台的话,真心做不到,所以我一般会选择套用一些开源UI模板来进行系统UI的设计.那如何套用呢?今天 ...

  7. 挪过来的spring mvc 的入门 介绍

    目录  一.前言二.spring mvc 核心类与接口三.spring mvc 核心流程图 四.spring mvc DispatcherServlet说明 五.spring mvc 父子上下文的说明 ...

  8. C# MVC 用户登录状态判断 【C#】list 去重(转载) js 日期格式转换(转载) C#日期转换(转载) Nullable<System.DateTime>日期格式转换 (转载) Asp.Net MVC中Action跳转(转载)

    C# MVC 用户登录状态判断   来源:https://www.cnblogs.com/cherryzhou/p/4978342.html 在Filters文件夹下添加一个类Authenticati ...

  9. MVC模式的介绍(C#)

    MVC模式的介绍(C#)   Benefits在开发项目中使用“模型-视图-控制器(MVC)”模式的好处在于可以完全消除商业流程和应用表达层之间的相互影响.此外,还可以获得一个完全独立的对象来控制表达 ...

随机推荐

  1. 前端PHP入门-035-Session的实例

      登陆例子:(请注意一定要自己敲一遍,不要CV大法) 首先上一下成果图,激起同学们写的欲望,登录页如下: 点击登陆之后如下: 说明哦了,么问题.接下来自己实现一下. 首先数据库信息: 新建一个名为 ...

  2. Jenkins使用教程之创建job

    第一部分:常规设置(general) 1.点击新建,进入新建项目页面 2.输入项目名称,选择构建一个自由风格的软件项目(里面可以自己自由进行配置,使用更加灵活),点击ok 3.项目名称与描述 4.gi ...

  3. stat命令--文件权限属性设置

    stat命令文件权限属性设置 stat命令用于显示文件的状态信息. stat命令的输出信息比ls命令的输出信息要更详细. 语法 stat(选项)(参数) 选项 -L:支持符号连接: -f:显示文件系统 ...

  4. 【BZOJ】2301: [HAOI2011]Problem b

    [题意]于给出的n个询问,每次求有多少个数对(x,y),满足a≤x≤b,c≤y≤d,且gcd(x,y) = k,gcd(x,y)函数为x和y的最大公约数.n,a,b,c,d,k<=50000. ...

  5. 在iOS开发中如何播放视频

     技术博客http://www.cnblogs.com/ChenYilong/  新浪微博http://weibo.com/luohanchenyilong  如何播放视频 •iOS提供了叫做MPMo ...

  6. bootstrap-select,selectpicker 用法详细:通过官方文档翻译

    用过selectpicker的都说好~但是网上中文的教程又找不到比较完整的用法,于是去官网看了下 顺便弄过来翻译一下: 选项可以通过数据属性或JavaScript传递.对于数据属性,附加选项名称dat ...

  7. 2017ACM暑期多校联合训练 - Team 8 1002 HDU 6134 Battlestation Operational (数论 莫比乌斯反演)

    题目链接 Problem Description The Death Star, known officially as the DS-1 Orbital Battle Station, also k ...

  8. Android Service使用简单介绍

    作为一个android初学者,经常对service的使用感到困惑.今天结合Google API 对Service这四大组件之一,进行简单使用说明. 希望对和我一样的初学者有帮助,如有不对的地方,也希望 ...

  9. 利用PCA可视化异常点

    异常点往往是由于某一个特征或者多个特征数值异常.但是对于多维度特征无法直接进行可视化观测异常点,利用PCA技术进行维度缩减,可以在二维或者三维空间上进行可视化展示. 原数据如下: from sklea ...

  10. python基础之内置异常对象

    前言 什么叫异常?简单来说就是程序运行发生了预计结果之外的情况从而导致程序无法正常运行.而python解释器将一些常见的异常情况在它发生时打包成一个异常对象,我们可以通过捕捉这些异常对象从而进行处理, ...