ASP.NET MVC下Bundle的使用

来源:http://www.cnblogs.com/godbell/archive/2017/08/21/7407129.html
-Advertisement-
Play Games

ASP.NET MVC中Bundle是用於打包捆綁資源的(一般是css和js),它是在全局文件Global.asax.cs中註冊Bundle,而註冊的具體實現預設是在App_Start文件夾的BundleConfig.cs中 為了便於說明,這裡在HomeController下新建一個Action,如 ...


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>
View Code

前臺瀏覽看效果(當瀏覽器足夠大時是橫向平鋪的,如果將瀏覽器縮小,則是垂直平鋪,示例中的表單部分最能體現出來):

 

 


改進
上面的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模式,此時需要設置:

 



您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 相信大家大多都聽過linux 的編譯安裝,但它到底是怎麼把源代碼變為自己電腦里可以應用的軟體哪?今天,小編就以httpd 為例詳細講解一下。 什麼是編譯安裝——編譯:將源代碼變為機器可執行的代碼文件。安裝:將可執行文件安裝到操作系統里,才可以使用。 一、下載httpd最新版本的源碼包 (1)如果電腦 ...
  • 打開http://mirrors.aliyun.com/,查找mariadb,然後拼裝地址http://mirrors.aliyun.com/mariadb/yum打開,點開你想要的版本,選擇你的操作系統點進去,複製地址,我這裡是 http://mirrors.aliyun.com/mariadb/ ...
  • 安裝openresty需要的庫 apt-get install libreadline-dev libncurses5-dev libpcre3-dev libssl-dev perl make build-essential 構建 OpenResty 進入下載好的壓縮包文件中用下麵的命令進行解壓  ...
  • vim萌新入門 vim進階教程 vim鍵點陣圖 vim官方文檔 vim維基百科 vi/vim是什麼? 是個文本編輯器。 按鍵說明: 第一部分:一般模式可用的移動游標、複製粘貼、搜索替換等。 移動游標的方法 h 或 向左箭頭鍵(←) 游標向左移動一個字元 j 或 向下箭頭鍵(↓) 游標向下移動一個字元 ...
  • Semaphore:可理解為允許線程執行信號的池子,池子中放入多少個信號就允許多少線程同時執行。 ...
  • AutoResetEvent自動重置事件,與ManualResetEvent是相對的而言 ...
  • ManualResetEvent手動重置事件,它用於現場間同步時用法非常簡單也易於理解。 ...
  • ASP.NET Core 是一個控制台應用程式,在其 main 方法中創建一個Web伺服器,以下是program.cs中的代碼: Main 方法調用 WebHost.CreateDefaultBuilder ,它遵循建造者模式來創建 web application host 。 builder 定義 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...