ASP.NET MVC4之js css文件合并功能(3)
MVC4增加了一些新功能,接下來(lái),我們來(lái)研究下MVC4中的新增功能,我們?cè)谛陆ㄒ粋€(gè)MVC4項(xiàng)目的時(shí)候,會(huì)發(fā)現(xiàn)在項(xiàng)目下多出了一個(gè)App_Start文件夾,文件夾下面有4個(gè)文件,BundleConfig.cs,F(xiàn)ilterConfig.cs,RouteConfig.cs,WebApiConfig.cs,其中BundleConfig.cs文件就是我們這一節(jié)要講的的文件。
眾所周知,瀏覽器在向服務(wù)器發(fā)送請(qǐng)求的時(shí)候,請(qǐng)求的文件連接數(shù)量是有限制的。使用BundleConfig可以將多個(gè)文件請(qǐng)求和并成一個(gè)請(qǐng)求,去除文件中的一些注釋?zhuān)瞻?,壓縮文件的大小,自動(dòng)合并壓縮優(yōu)化代碼,縮短響應(yīng)時(shí)間,提高網(wǎng)頁(yè)速度,起到優(yōu)化網(wǎng)站的作用。
1.定義分組
創(chuàng)建MVC4項(xiàng)目后,我們會(huì)在global.asax文件中的Application_Start()方法中看到如下代碼,起到注冊(cè)作用
BundleConfig.RegisterBundles(BundleTable.Bundles);
BundleConfig.cs代碼:
public class BundleConfig { // 有關(guān) Bundling 的詳細(xì)信息,請(qǐng)?jiān)L問(wèn) 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 的開(kāi)發(fā)版本進(jìn)行開(kāi)發(fā)和了解信息。然后,當(dāng)你做好 // 生產(chǎn)準(zhǔn)備時(shí),請(qǐng)使用 http://modernizr.com 上的生成工具來(lái)僅選擇所需的測(cè)試。 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是一個(gè)集合,用于將綁定規(guī)則添加到集合中,使用Add方法.
bundles.Add(new ScriptBundle("~/bundles/jquery").Include( "~/Scripts/jquery-{version}.js"));
new ScriptBundle("~/bundles/jquery")定義一個(gè)分組名稱(chēng),Include表示這個(gè)分組下具體包括的文件。
version參數(shù)代表版本號(hào) ,*代表所有,這兩個(gè)是可以理解為通配符。
以上代碼表示創(chuàng)建一個(gè)~/bundles/jquery分組,該分組指向的文件為scripts文件夾下的jquery-1.7.1.js文件。
如果scripts文件夾下有jquery-1.7.1.js,jquery-1.6.1.js,則會(huì)指向這兩個(gè)文件。
同樣,bundles.Add(new StyleBundle("~/Content/css").Include("~/Content/site.css"));表示創(chuàng)建了一個(gè)~/Content/css分組,指向~/Content/site.css文件.
2.使用分組
分組已經(jīng)定義好,我們接下演示怎樣使用。
如果在頁(yè)面中使用scripts,可以使用@Scripts.Render("~/bundles/jquery")方法,參數(shù)為分組名稱(chēng)
如果在頁(yè)面中使用css,可以使用@Styles.Render("~/Content/css")方法,參數(shù)為分組名稱(chēng).
可以看下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)目后,可以查看頁(yè)面源代碼,效果如下
3.合并請(qǐng)求
接下來(lái)我們通過(guò)分組將請(qǐng)求多個(gè)文件合并成請(qǐng)求一個(gè),可以使用如下兩種方法來(lái)實(shí)現(xiàn)
1).將web.config中的編譯調(diào)試debug設(shè)為false <compilation debug="false" targetFramework="4.5"/>
2).在BundleConfig中的方法末尾添加 BundleTable.EnableOptimizations = true;
再次運(yùn)行頁(yè)面,可以看到生成如下代碼
src="/bundles/jquery?v=wBUqTIMTmGl9Hj0haQMeRbd8CoM3UaGnAwp4uDEKfnM1"
?前面是分組名稱(chēng),后面是多個(gè)文件合并后生成的哈希碼
4.對(duì)比效果
我們?cè)诨鸷掠胒irebug查看合并前后的對(duì)比效果,可以對(duì)比下請(qǐng)求的文件大小,時(shí)間等方面的差別還是挺大的
壓縮合并前:
壓縮合并后:
注:默認(rèn)情況下 BundleTable.Bundles會(huì)過(guò)濾掉后綴名為這些的文件,intellisense.js、-vsdoc.js、.debug.js、.min.js、.min.css,
當(dāng)加載后綴名為這些的文件,將顯示空白。
可以用如下方法去除對(duì)這些文件過(guò)濾限制
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);
我們通過(guò)分組將請(qǐng)求多個(gè)文件合并成請(qǐng)求一個(gè),壓縮文件的大小,自動(dòng)合并壓縮優(yōu)化代碼,縮短響應(yīng)時(shí)間,提高網(wǎng)頁(yè)速度。希望通過(guò)本文可以幫助大家更好的優(yōu)化網(wǎng)站。
相關(guān)文章
asp.net 頁(yè)面?zhèn)髦档膸讉€(gè)方法
在網(wǎng)頁(yè)應(yīng)用程序的開(kāi)發(fā)中,頁(yè)面之間的傳值應(yīng)該是最常見(jiàn)的問(wèn)題了。2009-11-11.Net Web Api中利用FluentValidate進(jìn)行參數(shù)驗(yàn)證的方法
最近在做Web API,用到了流式驗(yàn)證,就簡(jiǎn)單的說(shuō)說(shuō)這個(gè)流式驗(yàn)證,下面這篇文章主要給大家介紹了關(guān)于.Net Web Api中利用FluentValidate進(jìn)行參數(shù)驗(yàn)證的相關(guān)資料,,需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07ASP.NET中操作數(shù)據(jù)庫(kù)的基本步驟分享
ASP.NET中操作數(shù)據(jù)庫(kù)的基本步驟分享,學(xué)習(xí)asp.net的朋友可以參考下。2011-10-10ASP.NET與ASP互通COOKIES的一點(diǎn)經(jīng)驗(yàn)
ASP與ASP.NET互相整合時(shí),其中文COOKIES信息無(wú)法被互通共享,當(dāng)使用ASP.NET寫(xiě)入中文COOKIES信息后,使用ASP進(jìn)行讀取,讀出來(lái)的卻是亂碼,而非中文。2010-03-03ASP.NET獲取不到JS設(shè)置cookies的解決方法
有時(shí)候通過(guò)一個(gè)頁(yè)面設(shè)置的js,在其它的子頁(yè)面或父頁(yè)面就無(wú)法正常獲取,主要是因?yàn)槁窂降膯?wèn)題, 設(shè)置到根目錄中即可。下面是具體的解決方法。2010-12-12創(chuàng)建一個(gè)ASP.NET MVC5項(xiàng)目的實(shí)現(xiàn)方法(圖文)
這篇文章主要介紹了創(chuàng)建一個(gè)ASP.NET MVC 5項(xiàng)目,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09淺談ASP.Net Core WebApi幾種版本控制對(duì)比
這篇文章主要介紹了淺談ASP.Net Core WebApi幾種版本控制對(duì)比,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09.NET CORE中比較兩個(gè)文件內(nèi)容是否相同的最快方法
這篇文章主要給大家介紹了關(guān)于.NET CORE中比較兩個(gè)文件內(nèi)容是否相同的最快方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用.NET CORE具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06asp.net 分頁(yè)顯示數(shù)據(jù)表的數(shù)據(jù)的代碼
asp.net顯示第一頁(yè)、上一頁(yè)、下一頁(yè)和最后一頁(yè)的分頁(yè)顯示數(shù)據(jù)表的數(shù)據(jù)2010-03-03