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下新建1个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>

浏览页面,查看源代码,能够见见:

Bootstrap 1

 

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示例代码,如下:

Bootstrap 2Bootstrap 3

@{
    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>

View
Code

前台浏览看功能(当浏览器丰富大时是横向平铺的,假若将浏览器裁减,则是笔直平铺,示例中的表单部分最能显示出来):

Bootstrap 4

 

 

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

再一次编写翻译,再一次浏览刚才的页面,那时发现引进了压缩版的财富(css/js)

注:由于示例时行使了ASP.NET MVC 五( .Net
Framework 四.⑤),而在.net framework 四中的asp.net mvc
四恐怕会有上边包车型客车情形:

在页面查看源代码时意识脚本贫乏引进~/Scripts/bootstrap.min.js,那是asp.net
mvc 四使用的System.Web.Optimization.dll私下认可使用了忽略规则*.min.js,那时能够在BundleConfig.cs的RegisterBundles中清除忽略规则

Bootstrap 5

 

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


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

Bootstrap 6

Bootstrap, 

相关文章