亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ASP.NET MVC4之js css文件合并功能(3)

 更新時間:2022年04月27日 14:32:15   作者:zx13525079024  
這篇文章主要介紹了ASP.NET MVC4之js css文件合并功能,使用BundleConfig可以將多個文件請求和并成一個請求,去除文件中的一些注釋,空白,起到優(yōu)化網(wǎng)站的作用,需要的朋友可以參考下

MVC4增加了一些新功能,接下來,我們來研究下MVC4中的新增功能,我們在新建一個MVC4項目的時候,會發(fā)現(xiàn)在項目下多出了一個App_Start文件夾,文件夾下面有4個文件,BundleConfig.cs,F(xiàn)ilterConfig.cs,RouteConfig.cs,WebApiConfig.cs,其中BundleConfig.cs文件就是我們這一節(jié)要講的的文件。

眾所周知,瀏覽器在向服務器發(fā)送請求的時候,請求的文件連接數(shù)量是有限制的。使用BundleConfig可以將多個文件請求和并成一個請求,去除文件中的一些注釋,空白,壓縮文件的大小,自動合并壓縮優(yōu)化代碼,縮短響應時間,提高網(wǎng)頁速度,起到優(yōu)化網(wǎng)站的作用。

1.定義分組

創(chuàng)建MVC4項目后,我們會在global.asax文件中的Application_Start()方法中看到如下代碼,起到注冊作用
BundleConfig.RegisterBundles(BundleTable.Bundles);

BundleConfig.cs代碼:

public class BundleConfig 
 { 
  // 有關(guān) Bundling 的詳細信息,請訪問 http://go.microsoft.com/fwlink/?LinkId=254725 
  public static void RegisterBundles(BundleCollection bundles) 
  { 
   bundles.Add(new ScriptBundle("~/bundles/jquery").Include( 
      "~/Scripts/jquery-{version}.js")); 
 
   bundles.Add(new ScriptBundle("~/bundles/jqueryui").Include( 
      "~/Scripts/jquery-ui-{version}.js")); 
 
   bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include( 
      "~/Scripts/jquery.unobtrusive*", 
      "~/Scripts/jquery.validate*")); 
 
   // 使用 Modernizr 的開發(fā)版本進行開發(fā)和了解信息。然后,當你做好 
   // 生產(chǎn)準備時,請使用 http://modernizr.com 上的生成工具來僅選擇所需的測試。 
   bundles.Add(new ScriptBundle("~/bundles/modernizr").Include( 
      "~/Scripts/modernizr-*")); 
 
   bundles.Add(new StyleBundle("~/Content/css").Include("~/Content/site.css")); 
 
   bundles.Add(new StyleBundle("~/Content/themes/base/css").Include( 
      "~/Content/themes/base/jquery.ui.core.css", 
      "~/Content/themes/base/jquery.ui.resizable.css", 
      "~/Content/themes/base/jquery.ui.selectable.css", 
      "~/Content/themes/base/jquery.ui.accordion.css", 
      "~/Content/themes/base/jquery.ui.autocomplete.css", 
      "~/Content/themes/base/jquery.ui.button.css", 
      "~/Content/themes/base/jquery.ui.dialog.css", 
      "~/Content/themes/base/jquery.ui.slider.css", 
      "~/Content/themes/base/jquery.ui.tabs.css", 
      "~/Content/themes/base/jquery.ui.datepicker.css", 
      "~/Content/themes/base/jquery.ui.progressbar.css", 
      "~/Content/themes/base/jquery.ui.theme.css")); 
  } 
 } 

BundleCollection是一個集合,用于將綁定規(guī)則添加到集合中,使用Add方法.
bundles.Add(new ScriptBundle("~/bundles/jquery").Include( "~/Scripts/jquery-{version}.js"));
new ScriptBundle("~/bundles/jquery")定義一個分組名稱,Include表示這個分組下具體包括的文件。
version參數(shù)代表版本號 ,*代表所有,這兩個是可以理解為通配符。
以上代碼表示創(chuàng)建一個~/bundles/jquery分組,該分組指向的文件為scripts文件夾下的jquery-1.7.1.js文件。
如果scripts文件夾下有jquery-1.7.1.js,jquery-1.6.1.js,則會指向這兩個文件。

同樣,bundles.Add(new StyleBundle("~/Content/css").Include("~/Content/site.css"));表示創(chuàng)建了一個~/Content/css分組,指向~/Content/site.css文件.

2.使用分組

分組已經(jīng)定義好,我們接下演示怎樣使用。
如果在頁面中使用scripts,可以使用@Scripts.Render("~/bundles/jquery")方法,參數(shù)為分組名稱
如果在頁面中使用css,可以使用@Styles.Render("~/Content/css")方法,參數(shù)為分組名稱.
可以看下VIEWS文件夾下的Shard文件夾的_Layout.cshtml文件

<!DOCTYPE html> 
<html> 
<head> 
 <meta charset="utf-8" /> 
 <meta name="viewport" content="width=device-width" /> 
 <title>@ViewBag.Title</title> 
 @Styles.Render("~/Content/css") 
 @Scripts.Render("~/bundles/modernizr") 
</head> 
<body> 
 @RenderBody() 
 
 @Scripts.Render("~/bundles/jquery") 
 @RenderSection("scripts", required: false) 
</body> 
</html> 

運行項目后,可以查看頁面源代碼,效果如下

3.合并請求

接下來我們通過分組將請求多個文件合并成請求一個,可以使用如下兩種方法來實現(xiàn)

1).將web.config中的編譯調(diào)試debug設為false <compilation debug="false" targetFramework="4.5"/>
2).在BundleConfig中的方法末尾添加 BundleTable.EnableOptimizations = true;
再次運行頁面,可以看到生成如下代碼
src="/bundles/jquery?v=wBUqTIMTmGl9Hj0haQMeRbd8CoM3UaGnAwp4uDEKfnM1"
?前面是分組名稱,后面是多個文件合并后生成的哈希碼

4.對比效果

我們在火狐下用firebug查看合并前后的對比效果,可以對比下請求的文件大小,時間等方面的差別還是挺大的

壓縮合并前:

壓縮合并后:

注:默認情況下 BundleTable.Bundles會過濾掉后綴名為這些的文件,intellisense.js、-vsdoc.js、.debug.js、.min.js、.min.css,
當加載后綴名為這些的文件,將顯示空白。
可以用如下方法去除對這些文件過濾限制

BundleTable.Bundles.IgnoreList.Clear(); 
BundleTable.Bundles.IgnoreList.Ignore(".min.js", OptimizationMode.Always); 
//BundleTable.Bundles.IgnoreList.Ignore("-vsdoc.js", OptimizationMode.Always); 
//BundleTable.Bundles.IgnoreList.Ignore(".debug.js", OptimizationMode.Always); 

我們通過分組將請求多個文件合并成請求一個,壓縮文件的大小,自動合并壓縮優(yōu)化代碼,縮短響應時間,提高網(wǎng)頁速度。希望通過本文可以幫助大家更好的優(yōu)化網(wǎng)站。

相關(guān)文章

  • asp.net 頁面?zhèn)髦档膸讉€方法

    asp.net 頁面?zhèn)髦档膸讉€方法

    在網(wǎng)頁應用程序的開發(fā)中,頁面之間的傳值應該是最常見的問題了。
    2009-11-11
  • .Net Web Api中利用FluentValidate進行參數(shù)驗證的方法

    .Net Web Api中利用FluentValidate進行參數(shù)驗證的方法

    最近在做Web API,用到了流式驗證,就簡單的說說這個流式驗證,下面這篇文章主要給大家介紹了關(guān)于.Net Web Api中利用FluentValidate進行參數(shù)驗證的相關(guān)資料,,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧
    2018-07-07
  • ASP.NET中操作數(shù)據(jù)庫的基本步驟分享

    ASP.NET中操作數(shù)據(jù)庫的基本步驟分享

    ASP.NET中操作數(shù)據(jù)庫的基本步驟分享,學習asp.net的朋友可以參考下。
    2011-10-10
  • ASP.NET與ASP互通COOKIES的一點經(jīng)驗

    ASP.NET與ASP互通COOKIES的一點經(jīng)驗

    ASP與ASP.NET互相整合時,其中文COOKIES信息無法被互通共享,當使用ASP.NET寫入中文COOKIES信息后,使用ASP進行讀取,讀出來的卻是亂碼,而非中文。
    2010-03-03
  • ASP.NET獲取不到JS設置cookies的解決方法

    ASP.NET獲取不到JS設置cookies的解決方法

    有時候通過一個頁面設置的js,在其它的子頁面或父頁面就無法正常獲取,主要是因為路徑的問題, 設置到根目錄中即可。下面是具體的解決方法。
    2010-12-12
  • 創(chuàng)建一個ASP.NET MVC5項目的實現(xiàn)方法(圖文)

    創(chuàng)建一個ASP.NET MVC5項目的實現(xiàn)方法(圖文)

    這篇文章主要介紹了創(chuàng)建一個ASP.NET MVC 5項目,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • 淺談ASP.Net Core WebApi幾種版本控制對比

    淺談ASP.Net Core WebApi幾種版本控制對比

    這篇文章主要介紹了淺談ASP.Net Core WebApi幾種版本控制對比,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • .NET CORE中比較兩個文件內(nèi)容是否相同的最快方法

    .NET CORE中比較兩個文件內(nèi)容是否相同的最快方法

    這篇文章主要給大家介紹了關(guān)于.NET CORE中比較兩個文件內(nèi)容是否相同的最快方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用.NET CORE具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • asp.net下PageMethods使用技巧

    asp.net下PageMethods使用技巧

    ASP.net AjAX中的PageMethods可以將靜態(tài)頁方法添加到 ASP.NET 頁中并將其用作 Web 方法。然后,無需創(chuàng)建單獨的 .asmx 文件即可從該頁中的腳本調(diào)用這些方法,就好像這些方法是 Web 服務的一部分。特別是在一些交互流程不復雜而調(diào)用次數(shù)和方法又比較多的情況下更為方便。因為PageMethods不需要我們再添加另外的WEB服務或Page來處理請求。
    2008-03-03
  • asp.net 分頁顯示數(shù)據(jù)表的數(shù)據(jù)的代碼

    asp.net 分頁顯示數(shù)據(jù)表的數(shù)據(jù)的代碼

    asp.net顯示第一頁、上一頁、下一頁和最后一頁的分頁顯示數(shù)據(jù)表的數(shù)據(jù)
    2010-03-03

最新評論