查看: 1684|回复: 0

[.NET开发] ASP.NET MVC下Bundle的使用方法

发表于 2018-1-2 08:00:00

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

  1. public class MvcApplication : System.Web.HttpApplication
  2. {
  3. protected void Application_Start()
  4. {
  5. AreaRegistration.RegisterAllAreas();
  6. FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
  7. RouteConfig.RegisterRoutes(RouteTable.Routes);
  8. BundleConfig.RegisterBundles(BundleTable.Bundles);
  9. }
  10. }
复制代码

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

  1. public class BundleConfig
  2. {
  3. // 有关绑定的详细信息,请访问 http://go.microsoft.com/fwlink/?LinkId=301862
  4. public static void RegisterBundles(BundleCollection bundles)
  5. {
  6. bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
  7. "~/Scripts/jquery-{version}.js"));
  8. bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
  9. "~/Scripts/jquery.validate*"));
  10. // 使用要用于开发和学习的 Modernizr 的开发版本。然后,当你做好
  11. // 生产准备时,请使用 http://modernizr.com 上的生成工具来仅选择所需的测试。
  12. bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
  13. "~/Scripts/modernizr-*"));
  14. bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include(
  15. "~/Scripts/bootstrap.js",
  16. "~/Scripts/respond.js"));
  17. bundles.Add(new StyleBundle("~/Content/css").Include(
  18. "~/Content/bootstrap.css",
  19. "~/Content/site.css"));
  20. }
  21. }
复制代码

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

  1. public ActionResult BundleTest()
  2. {
  3. return View();
  4. }
复制代码

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

  1. @{
  2. Layout = null;
  3. }
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta name="viewport" content="width=device-width" />
  8. <title>BundleTest</title>
  9. @Styles.Render("~/Content/css")
  10. </head>
  11. <body>
  12. @Scripts.Render("~/bundles/jquery", "~/bundles/bootstrap")
  13. </body>
  14. </html>
复制代码

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

  1. bundles.Add(new StyleBundle("~/Content/css").Include(
  2. "~/Content/bootstrap.css",
  3. "~/Content/site.css"));
复制代码

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

  1. @{
  2. Layout = null;
  3. }
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta name="viewport" content="width=device-width" />
  8. <title>BundleTest</title>
  9. @Styles.Render("~/Content/css")
  10. </head>
  11. <body>
  12. <div class="container">
  13. <div class="header clearfix">
  14. <nav>
  15. <ul class="nav nav-pills pull-right">
  16. <li role="presentation" class="active"><a href="#">首页</a></li>
  17. <li role="presentation"><a href="#">关于我们</a></li>
  18. <li role="presentation"><a href="#">联系我们</a></li>
  19. </ul>
  20. </nav>
  21. </div>
  22. <form class="form-horizontal">
  23. <div class="form-group">
  24. <label for="username" class="col-sm-2 control-label">用户名</label>
  25. <div class="col-sm-10">
  26. <input type="text" class="form-control" id="username" placeholder="用户名">
  27. </div>
  28. </div>
  29. <div class="form-group">
  30. <label for="password" class="col-sm-2 control-label">密码</label>
  31. <div class="col-sm-10">
  32. <input type="password" class="form-control" id="password" placeholder="密码">
  33. </div>
  34. </div>
  35. <div class="form-group">
  36. <label for="code" class="col-sm-2 control-label">验证码</label>
  37. <div class="col-sm-10">
  38. <input type="text" class="form-control" id="code" placeholder="验证码">
  39. </div>
  40. </div>
  41. <div class="form-group">
  42. <div class="col-sm-offset-2 col-sm-10">
  43. <div class="checkbox">
  44. <label>
  45. <input type="checkbox"> 记住我
  46. </label>
  47. </div>
  48. </div>
  49. </div>
  50. <div class="form-group">
  51. <div class="col-sm-offset-2 col-sm-10">
  52. <button type="submit" class="btn btn-default">登录</button>
  53. </div>
  54. </div>
  55. </form>
  56. <footer class="footer">
  57. <p>? 2017 Zhong.</p>
  58. </footer>
  59. </div> <!-- /container -->
  60. @Scripts.Render("~/bundles/jquery", "~/bundles/bootstrap")
  61. </body>
  62. </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模式,此时需要设置:

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



回复

使用道具 举报