婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > ASP.NET MVC4之js css文件合并功能(3)

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

熱門標(biāo)簽:西寧電銷外呼系統(tǒng)公司 上海市三維地圖標(biāo)注 云南外呼系統(tǒng)代理 辦公用地圖標(biāo)注網(wǎng)點(diǎn)怎么操作 南昌自動外呼系統(tǒng)線路 海東防封電銷卡 聊城智能電銷機(jī)器人電話 寧德防封版電銷卡 安陸市地圖標(biāo)注app

MVC4增加了一些新功能,接下來,我們來研究下MVC4中的新增功能,我們在新建一個MVC4項(xiàng)目的時候,會發(fā)現(xiàn)在項(xiàng)目下多出了一個App_Start文件夾,文件夾下面有4個文件,BundleConfig.cs,F(xiàn)ilterConfig.cs,RouteConfig.cs,WebApiConfig.cs,其中BundleConfig.cs文件就是我們這一節(jié)要講的的文件。
眾所周知,瀏覽器在向服務(wù)器發(fā)送請求的時候,請求的文件連接數(shù)量是有限制的。使用BundleConfig可以將多個文件請求和并成一個請求,去除文件中的一些注釋,空白,壓縮文件的大小,自動合并壓縮優(yōu)化代碼,縮短響應(yīng)時間,提高網(wǎng)頁速度,起到優(yōu)化網(wǎng)站的作用。
1.定義分組
創(chuàng)建MVC4項(xiàng)目后,我們會在global.asax文件中的Application_Start()方法中看到如下代碼,起到注冊作用
BundleConfig.RegisterBundles(BundleTable.Bundles);
BundleConfig.cs代碼:

public class BundleConfig 
 { 
  // 有關(guān) Bundling 的詳細(xì)信息,請訪問 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ā)版本進(jìn)行開發(fā)和了解信息。然后,當(dāng)你做好 
   // 生產(chǎn)準(zhǔ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> 

運(yùn)行項(xiàng)目后,可以查看頁面源代碼,效果如下

3.合并請求
接下來我們通過分組將請求多個文件合并成請求一個,可以使用如下兩種方法來實(shí)現(xiàn)
1).將web.config中的編譯調(diào)試debug設(shè)為false compilation debug="false" targetFramework="4.5"/>
2).在BundleConfig中的方法末尾添加 BundleTable.EnableOptimizations = true;
再次運(yùn)行頁面,可以看到生成如下代碼
src="/bundles/jquery?v=wBUqTIMTmGl9Hj0haQMeRbd8CoM3UaGnAwp4uDEKfnM1"
?前面是分組名稱,后面是多個文件合并后生成的哈希碼

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

壓縮合并后:

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

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)化代碼,縮短響應(yīng)時間,提高網(wǎng)頁速度。希望通過本文可以幫助大家更好的優(yōu)化網(wǎng)站。

您可能感興趣的文章:
  • datalist,Repeater和Gridview的區(qū)別分析
  • asp.net中讓Repeater和GridView支持DataPager分頁
  • repeater、gridview 在綁定時判斷判斷顯示不同的行樣式或文本
  • Asp.net程序優(yōu)化js、css實(shí)現(xiàn)合并與壓縮的方法
  • Asp.net_Table控件の單元格縱向合并示例
  • ASP.NET GridView 實(shí)現(xiàn)課程表顯示(動態(tài)合并單元格)實(shí)現(xiàn)步驟
  • asp.net中GridView和DataGrid相同列合并實(shí)現(xiàn)代碼
  • asp.net中rdlc 合并行的方法
  • asp.net 合并GridView中某列相同信息的行(單元格)
  • ASP.NET中GridView和Repeater重復(fù)數(shù)據(jù)如何合并

標(biāo)簽:崇左 青海 南寧 衢州 洛陽 贛州 汕尾

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET MVC4之js css文件合并功能(3)》,本文關(guān)鍵詞  ASP.NET,MVC4,之,css,文件,合并,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET MVC4之js css文件合并功能(3)》相關(guān)的同類信息!
  • 本頁收集關(guān)于ASP.NET MVC4之js css文件合并功能(3)的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章
    主站蜘蛛池模板: 钟祥市| 敦煌市| 华安县| 兴宁市| 宣威市| 昭通市| 仙游县| 广西| 江源县| 若尔盖县| 开封市| 铜川市| 新乐市| 安新县| 临洮县| 闽清县| 略阳县| 莆田市| 应用必备| 土默特右旗| 剑河县| 水城县| 阿拉善右旗| 余干县| 蒙山县| 通渭县| 时尚| 睢宁县| 丰都县| 格尔木市| 阳江市| 博湖县| 万山特区| 拜城县| 界首市| 中宁县| 顺昌县| 茂名市| 天峨县| 东阿县| 繁峙县|