当前位置: 首页 > news >正文

[Asp.net MVC]Bundle合并,压缩js、css文件

摘要

在web优化中有一种手段,压缩js,css文件,减少文件大小,合并js,css文件减少请求次数。asp.net mvc中为我们提供一种使用c#代码压缩合并js和css这类静态文件的方法。

一个例子

新建asp.net mvc项目,在App_Start文件夹中你可以看到一个叫做BundleConfig.cs的类,

该类内容如下:

 public class BundleConfig
    {
        // For more information on bundling, visit http://go.microsoft.com/fwlink/?LinkId=301862
        public static void RegisterBundles(BundleCollection bundles)
        {
            bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                        "~/Scripts/jquery-{version}.js"));

            bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
                        "~/Scripts/jquery.validate*"));

            // Use the development version of Modernizr to develop with and learn from. Then, when you're
            // ready for production, use the build tool at http://modernizr.com to pick only the tests you need.
            bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
                        "~/Scripts/modernizr-*"));

            bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include(
                      "~/Scripts/bootstrap.js",
                      "~/Scripts/respond.js"));

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

如上代码所示,压缩和合并分两种对象ScriptBundle和StyleBundle。

namespace System.Web.Optimization
{
    //
    // Summary:
    //     Represents a bundle that does Js Minification.
    public class ScriptBundle : Bundle
    {
        //
        // Summary:
        //     Initializes a new instance of the System.Web.Optimization.ScriptBundle class
        //     that takes a virtual path for the bundle.
        //
        // Parameters:
        //   virtualPath:
        //     The virtual path for the bundle.
        public ScriptBundle(string virtualPath);
        //
        // Summary:
        //     Initializes a new instance of the System.Web.Optimization.ScriptBundle class
        //     that takes virtual path and cdnPath for the bundle.
        //
        // Parameters:
        //   virtualPath:
        //     The virtual path for the bundle.
        //
        //   cdnPath:
        //     The path of a Content Delivery Network (CDN).
        public ScriptBundle(string virtualPath, string cdnPath);
    }
}

ScriptBundle有两个构造函数,virtualPath:js文件的虚拟路径,cdnPath:js的网络cdn路径。StyleBundle的构造函数的参数与ScriptBundle相同。

在上面的代码片段中你可以看到

jquery-{version}.js:其中version是jquery的版本号,version是一个版本号的占位符。
jquery.validate*:*通配符,匹配所有。

上面的代码完成后,需要在Global.asax的Application_start事件中对其注册。

如何使用?

在视图中,通过下面的代码实现对静态文件的引用。

浏览

怎么没起作用呢?Bundle默认在调试的情况下,是没有开启打包压缩的,可以通过下面的2中方式进行开启。

再浏览下

你会发现Jquery-1.10.2.js该文件在请求中已经不存在了,它已经被打包压缩在jquery?v=版本号,这个文件里面了。

另外一种打开打包压缩的方式,在web.config文件中中:

总结

上面就是对Bundle的用法介绍,对静态文件打包压缩可以减少请求次数,资源加载的速度。

转载于:https://www.cnblogs.com/wolf-sun/p/6441215.html

相关文章:

  • 初识kbmmw 5 中httpsys的支持
  • 算法笔记_052:蓝桥杯练习Multithreading(Java)
  • 单独一页插入页脚
  • 上传网站流程
  • Apache Mesos 官方文档 V1.0
  • asm 兼容性、asm 主要参数管理
  • 亲密数
  • C#中运算符的使用
  • win8、server 2012 清除winsxs文件夹
  • 让背景带上颜色
  • 模块化Javascript代码的两种方式
  • 远程下载图片,并且生产正确的图片格式
  • 虚拟社会(Virtual Society)
  • C++ struct 和 Class的区别
  • 给程序员最好的18个忠告!
  • php的引用
  • 《微软的软件测试之道》成书始末、出版宣告、补充致谢名单及相关信息
  • Android路由框架AnnoRouter:使用Java接口来定义路由跳转
  • EOS是什么
  • js
  • mongo索引构建
  • PhantomJS 安装
  • Spark VS Hadoop:两大大数据分析系统深度解读
  • Wamp集成环境 添加PHP的新版本
  • 马上搞懂 GeoJSON
  • 以太坊客户端Geth命令参数详解
  • 鱼骨图 - 如何绘制?
  • 【云吞铺子】性能抖动剖析(二)
  • LIGO、Virgo第三轮探测告捷,同时探测到一对黑洞合并产生的引力波事件 ...
  • Semaphore
  • ​你们这样子,耽误我的工作进度怎么办?
  • ​如何防止网络攻击?
  • (01)ORB-SLAM2源码无死角解析-(66) BA优化(g2o)→闭环线程:Optimizer::GlobalBundleAdjustemnt→全局优化
  • (10)Linux冯诺依曼结构操作系统的再次理解
  • (Java数据结构)ArrayList
  • (附源码)springboot 基于HTML5的个人网页的网站设计与实现 毕业设计 031623
  • (论文阅读23/100)Hierarchical Convolutional Features for Visual Tracking
  • (每日持续更新)jdk api之StringBufferInputStream基础、应用、实战
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (转)ObjectiveC 深浅拷贝学习
  • **Java有哪些悲观锁的实现_乐观锁、悲观锁、Redis分布式锁和Zookeeper分布式锁的实现以及流程原理...
  • .gitignore文件_Git:.gitignore
  • .net mvc actionresult 返回字符串_.NET架构师知识普及
  • .NET WebClient 类下载部分文件会错误?可能是解压缩的锅
  • .NET 中什么样的类是可使用 await 异步等待的?
  • .netcore 如何获取系统中所有session_如何把百度推广中获取的线索(基木鱼,电话,百度商桥等)同步到企业微信或者企业CRM等企业营销系统中...
  • .NET中统一的存储过程调用方法(收藏)
  • /bin、/sbin、/usr/bin、/usr/sbin
  • @开发者,一文搞懂什么是 C# 计时器!
  • [ vulhub漏洞复现篇 ] ECShop 2.x / 3.x SQL注入/远程执行代码漏洞 xianzhi-2017-02-82239600
  • [Android]Android开发入门之HelloWorld
  • [BT]BUUCTF刷题第4天(3.22)
  • [C/C++]数据结构 深入挖掘环形链表问题
  • [C++]指针与结构体
  • [C++参考]拷贝构造函数的参数必须是引用类型