ASP.NET MVC Bundle使用 合併壓縮

来源:http://www.cnblogs.com/wubh/archive/2016/12/04/6130981.html
-Advertisement-
Play Games

使用 Bundle 可以將多個 JS文件或 CSS 文件合併成一個文件,並且壓縮。這樣可減少瀏覽器需下載多個文件的請求時間,同時通過移除JS/CSS文件案中空白、批註及修改JavaScript內部函數、變數名稱的壓縮手法,能有效縮小文件案體積,提高傳輸效率,提高使用者的瀏覽體驗。 基本使用 Glob ...


使用 Bundle 可以將多個 JS文件或 CSS 文件合併成一個文件,並且壓縮。這樣可減少瀏覽器需下載多個文件的請求時間,同時通過移除JS/CSS文件案中空白、批註及修改JavaScript內部函數、變數名稱的壓縮手法,能有效縮小文件案體積,提高傳輸效率,提高使用者的瀏覽體驗。

基本使用

Global.asax

protected void Application_Start()
        {
            BundleConfig.RegisterBundles(BundleTable.Bundles);
        }

BundleConfig 

public static void RegisterBundles(BundleCollection bundles)
 {
            bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                        "~/Scripts/jquery-{version}.js"));

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

視圖

@Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/bootstrap")

啟用Bundle(合併壓縮)的2種方式

  1. BundleConfigRegisterBundles方法添加以下代碼

    public static void RegisterBundles(BundleCollection bundles)
    {
        bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                     "~/Scripts/jquery-{version}.js"));
    
        // 啟用合併壓縮
       BundleTable.EnableOptimizations = true;
    }
  2. 打開web.config文件,設置編譯的debug=false

      <system.web>
        <compilation debug="false" targetFramework="4.5" />
      </system.web>

變化效果

合併之後減少了請求的數量,JS文件和CSS文件大小都減少了,提高了頁面的載入速度。

合併壓縮前

合併壓縮後

註意事項

  • 合併壓縮後的文件預設緩存一年。如果你重覆打開網頁,並且配置的文件也沒有做修改的情況下,伺服器會返回一個 HTTP 304 的狀態碼,這樣瀏覽器會載入緩存中的文件。

  • 圖片路徑問題,將多個CSS合併在一起後,有的時候會導致圖片載入失敗的情況

    解決方法:圖片使用絕對路徑

  • BundleConfig 配置中配置的壓縮的文件是 a.js (未壓縮版本) ,並且在相同目錄中存在 a.min.js 文件。當你修改了 a.js 文件後,希望合併壓縮後的 JS 文件也包含修改後的內容,然而並非我們所希望的那樣,壓縮後的 JS 文件還是引用了a.min.js 中的內容,之前修改的並沒有出現在壓縮的 JS 文件中。同理,CSS也是如此。

 


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

-Advertisement-
Play Games
更多相關文章
  • 先看效果: 1.本文演示的是微信【企業號】的H5頁面微信支付 2.本項目基於開源微信框架WeiXinMPSDK開發:https://github.com/JeffreySu/WeiXinMPSDK 感謝作者蘇志巍的開源精神 一、準備部分 相關參數: AppId:公眾號的唯一標識(登陸微信企業號後臺 ...
  • 題外話 本篇分享不能幫助你入門vue,入門的文章也是無意義的,官方文檔http://cn.vuejs.org/v2/guide/ 已經寫的不能再清晰了。希望我們勇敢的主動地給自己創造實踐的機會。 手裡有一個功能還不是很多的PC端頁面,考慮到下一個版本,要把IOS,安卓和公眾號上擁有的功能也要添加到P ...
  • 欄目是網站的常用功能,按照慣例欄目分常規欄目,單頁欄目,鏈接欄目三種類型,這次主要做添加欄目控制器和欄目模型兩個內容,控制器這裡會用到特性路由,模型放入業務邏輯層中(網站計劃分數據訪問、業務邏輯和Web層,初步計劃劃分如下圖)。 一、欄目控制器 1、添加控制器 在Ninesky.Web項目項目Con... ...
  • 當你用 Visual Studio 2015 Update 3 打開從別處下載的開源項目的時候,如果發現 Bower 提示 "bower.json 中出現語法錯誤"。 請檢查一下.bowerrc文件的編碼格式是否為ANSI,如果不是,可以用Notepad++等文本編輯器工具,轉換編碼格式。 ...
  • 交流群:225443677 ...
  • ...
  • ...
  • 在本文中,我們將創建一個簡單的 Web API 來實現對一個 “todo” 列表的 CRUD 操作,使用 Apache Cassandra 來存儲數據,在這裡不會創建 UI ,Web API 的測試將使用 Postman 來完成。 ASP.NET Core 是 ASP.NET 的重大的重構,ASP. ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...