日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

第十一节:Bundles压缩合并js和css及原理分析

發布時間:2024/1/3 综合教程 31 生活家
生活随笔 收集整理的這篇文章主要介紹了 第十一节:Bundles压缩合并js和css及原理分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一. 簡介

1.背景:瀏覽器默認一次性請求的網絡數是有上限的,如果你得js和css文件太多,就會導致瀏覽器需要多次加載,影響頁面的加載速度, MVC中提供Bundles的方式壓縮合并js和css,是MVC中特有的一種優化方式。

(當然現在前端也有很多基于node的工作流插件,可以合并壓縮混淆js或css)

2. 原理(了解即可):核心方法ApplyTransforms,通過StreamReader不斷一次一次進行讀取

參考文檔:https://docs.microsoft.com/en-us/aspnet/mvc/overview/performance/bundling-and-minification

二. 如何使用

①:首先要在Global中進行注冊,代碼:BundleConfig.RegisterBundles(BundleTable.Bundles); 【系統默認已經注冊,此步驟不需要我們操作】

②:在BundleConfig類中進行自定義合并壓縮js或css

   a. 壓縮css方法:bundles.Add(new StyleBundle("~/XXX").Include("","",""));

    StyleBundle中的參數為一個虛擬路徑,單必須以【~/】開頭,后面自定義,該名稱即為在前端頁面引入的名稱。

    Include中的參數為一個可變的string數組,用來聲明要壓縮合并的css文件的路徑。

   b. 壓縮js方法:bundles.Add(new ScriptBundle("~/XXX").Include("","",""));

    ScriptBundle中的參數為一個虛擬路徑,單必須以【~/】開頭,后面自定義,該名稱即為在前端頁面引入的名稱

    Include中的參數為一個可變的string數組,用來聲明要壓縮合并的css文件的路徑。

③:在前端頁面通過Render方法或者原生方法引入合并后的js或css的虛擬目錄

④:將webconfig中的調試模式設置為false,這樣在不發布的情況下就可以看到壓縮后的效果。

    <compilation debug="false" targetFramework="4.5" />

  如果設置為true,直接在vs中運行,是看不到壓縮效果的,仍然是多個js或css文件 (適用于通過Render方式的引入)

⑤:該步驟和④的效果相同.

  如果不設置④的情況下,還想在vs中運行看到壓縮效果,也可以在BundleConfig中加一句話:

  BundleTable.EnableOptimizations = true; (特別注意:這里是true,而配置文件的方式是設置為false)

  (適用于通過Render方式的引入)

補充:通過表達式擴展:(詳細語法可以參考上面的地址,下面擴展幾個常用的)

①: T* 該目錄下以T開頭的js或css文件

②: *.js *.css 該目錄下的所有js或css文件

③: T*.js T*.css 這個是不合法,違規的

三. 代碼測試

1. 新建兩個js文件和css文件

2. 在BundleConfig文件中進行注冊

3. 編寫前端頁面,以傳統的方式引入,并查看效果。

4. 引入壓縮合并后的路徑。

方式一的運行結果:

方式二的運行結果:發現并沒有壓縮

至于為什么,上面已經解釋了。

解決方案:

  方案①:BundleTable.EnableOptimizations = true;

  方案②:<compilation debug="false" targetFramework="4.5" />

重新運行:

最后補充幾個含格式驗證的壓縮:

總結

以上是生活随笔為你收集整理的第十一节:Bundles压缩合并js和css及原理分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。