全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

ASP.NET MVC下Bundle的使用方法

ASP.NET MVC中Bundle是用于打包捆绑资源的(一般是css和js),它是在全局文件Global.asax.cs中注册Bundle,而注册的具体实现默认是在App_Start文件夹的BundleConfig.cs中

public class MvcApplication : System.Web.HttpApplication
{
 protected void Application_Start()
 {
  AreaRegistration.RegisterAllAreas();
  FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
  RouteConfig.RegisterRoutes(RouteTable.Routes);
  BundleConfig.RegisterBundles(BundleTable.Bundles);
 }
}

BundleConfig.RegisterBundles(BundleTable.Bundles); 在应用程序启用时注册Bundle

public class BundleConfig
{
 // 有关绑定的详细信息,请访问 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*"));

  // 使用要用于开发和学习的 Modernizr 的开发版本。然后,当你做好
  // 生产准备时,请使用 http://modernizr.com 上的生成工具来仅选择所需的测试。
  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"));
 }
}

为了便于说明,这里在HomeController下新建一个Action,如下:

public ActionResult BundleTest()
{
 return View();
}

这里以使用Bootstrap为例,在视图中使用@Styles.Render() 和@Scripts.Render() 引入css和js,参数是在BundleConfig注册的名称

@{
 Layout = null;
}
<!DOCTYPE html>
<html>
<head>
 <meta name="viewport" content="width=device-width" />
 <title>BundleTest</title>
 @Styles.Render("~/Content/css")
</head>
<body>
 
 @Scripts.Render("~/bundles/jquery", "~/bundles/bootstrap")
</body>
</html>

浏览页面,查看源代码,可以看到:

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

由于在BundleConfig.cs中注册上面的Bundle,@Styles.Render("~/Content/css")渲染时是引入~/Content/bootstrap.css和~/Content/site.css,js的渲染同理
为了验证是否真正引入了BootStrap的css与js资源,这里添加了一些简单的BootStrap示例代码,如下:

@{
 Layout = null;
}
<!DOCTYPE html>
<html>
<head>
 <meta name="viewport" content="width=device-width" />
 <title>BundleTest</title>
 @Styles.Render("~/Content/css")
</head>
<body>
 <div class="container">
  <div class="header clearfix">
   <nav>
    <ul class="nav nav-pills pull-right">
     <li role="presentation" class="active"><a href="#">首页</a></li>
     <li role="presentation"><a href="#">关于我们</a></li>
     <li role="presentation"><a href="#">联系我们</a></li>
    </ul>
   </nav>
  </div>
  <form class="form-horizontal">
   <div class="form-group">
    <label for="username" class="col-sm-2 control-label">用户名</label>
    <div class="col-sm-10">
     <input type="text" class="form-control" id="username" placeholder="用户名">
    </div>
   </div>
   <div class="form-group">
    <label for="password" class="col-sm-2 control-label">密码</label>
    <div class="col-sm-10">
     <input type="password" class="form-control" id="password" placeholder="密码">
    </div>
   </div>
   <div class="form-group">
    <label for="code" class="col-sm-2 control-label">验证码</label>
    <div class="col-sm-10">
     <input type="text" class="form-control" id="code" placeholder="验证码">
    </div>
   </div>
   <div class="form-group">
    <div class="col-sm-offset-2 col-sm-10">
     <div class="checkbox">
      <label>
       <input type="checkbox"> 记住我
      </label>
     </div>
    </div>
   </div>
   <div class="form-group">
    <div class="col-sm-offset-2 col-sm-10">
     <button type="submit" class="btn btn-default">登录</button>
    </div>
   </div>
  </form>
  <footer class="footer">
   <p>&copy; 2017 Zhong.</p>
  </footer>

 </div> <!-- /container -->
 @Scripts.Render("~/bundles/jquery", "~/bundles/bootstrap")
</body>
</html>

前台浏览看效果(当浏览器足够大时是横向平铺的,如果将浏览器缩小,则是垂直平铺,示例中的表单部分最能体现出来):

改进

上面的Bundle是引入了未压缩的css和js资源,但在实际应用中,出于为了减轻服务器负载等原因,需要引入压缩版的资源(一般是在未压缩的命名后面加上min来命名,如jquery.js的压缩版【有些叫法是精简版】是jquery.min.js)
于是修改BundleConfig.cs

重新编译,再次浏览刚才的页面,这时发现引入了压缩版的资源(css/js)

注:由于示例时使用了ASP.NET MVC 5( .Net Framework 4.5),而在.net framework 4中的asp.net mvc 4可能会有下面的情况:

在页面查看源代码时发现脚本缺少引入~/Scripts/bootstrap.min.js,这是asp.net mvc 4使用的System.Web.Optimization.dll默认使用了忽略规则*.min.js,这时可以在BundleConfig.cs的RegisterBundles中清除忽略规则

该解决方法一是通过反编译System.Web.Optimization.dll并结合反编译的代码得出来的,另外也可以参考这个链接

另外就是在部署生产环境时发现无效,因为生产环境不再是debug模式,此时需要设置:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# ASP.NET  # MVC  # Bundle  # Asp.net MVC下使用Bundle合并、压缩js与css文件详解  # ASP.NET MVC中使用Bundle打包压缩js和css的方法  # ASP.NET MVC Bundles 用法和说明(打包javascript和css)  # 使用asp.net MVC4中的Bundle遇到的问题及解决办法分享  # 基于Asp.Net MVC4 Bundle捆绑压缩技术的介绍  # 详解Asp.Net MVC的Bundle捆绑  # 是在  # 平铺  # 验证码  # 源代码  # 引入了  # 这是  # 反编译  # 使用了  # 会有  # 一是  # 则是  # 当你  # 但在  # 而在  # 所需  # 请使用  # 要用  # 可以看到  # 关于我们  # 为例 


相关文章: 头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  如何自定义建站之星网站的导航菜单样式?  测试制作网站有哪些,测试性取向的权威测试或者网站?  如何通过多用户协作模板快速搭建高效企业网站?  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  建站主机是否等同于虚拟主机?  长沙企业网站制作哪家好,长沙水业集团官方网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  如何在阿里云虚拟服务器快速搭建网站?  如何在Golang中使用replace替换模块_指定本地或远程路径  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  如何通过cPanel快速搭建网站?  如何用5美元大硬盘VPS安全高效搭建个人网站?  定制建站哪家更专业可靠?推荐榜单揭晓  如何快速搭建支持数据库操作的智能建站平台?  西安大型网站制作公司,西安招聘网站最好的是哪个?  建站之星3.0如何解决常见操作问题?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何用免费手机建站系统零基础打造专业网站?  如何通过.red域名打造高辨识度品牌网站?  浅析上传头像示例及其注意事项  建站168自助建站系统:快速模板定制与SEO优化指南  重庆市网站制作公司,重庆招聘网站哪个好?  如何通过NAT技术实现内网高效建站?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  如何选择最佳自助建站系统?快速指南解析优劣  网站制作服务平台,有什么网站可以发布本地服务信息?  宝塔建站教程:一键部署配置流程与SEO优化实战指南  如何在阿里云购买域名并搭建网站?  建站主机与虚拟主机有何区别?如何选择最优方案?  制作网站怎么制作,*游戏网站怎么搭建?  网站制作的步骤包括,正确网址格式怎么写?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  北京企业网站设计制作公司,北京铁路集团官方网站?  如何快速查询网址的建站时间与历史轨迹?  宁波免费建站如何选择可靠模板与平台?  5种Android数据存储方式汇总  制作宣传网站的软件,小红书可以宣传网站吗?  深圳网站制作案例,网页的相关名词有哪些?  手机网站制作与建设方案,手机网站如何建设?  深圳企业网站制作设计,在深圳如何网上全流程注册公司?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  个人摄影网站制作流程,摄影爱好者都去什么网站?  如何快速搭建高效可靠的建站解决方案?  建站之星如何实现PC+手机+微信网站五合一建站?  安云自助建站系统如何快速提升SEO排名?  武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?  如何快速搭建响应式可视化网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。