Introduction to Bundling and Minification in Asp.net/MVC

Bundling & Minification is a Website Performance Optimization approach provided with asp.net 4.5 version . 

It can be added to asp.net 4.0 version too with explicit installation from Nugget Package Manager tool. 

Bundling & Minification are two techniques we can use in ASP.NET to improve website load time. 

 These techniques improve load time by reducing the number of requests to the server and reducing the size of requested resources (CSS, Java Script).

Most of the current major browsers limit the number of simultaneous connections per each hostname to six.

That means that while six requests are being processed, additional requests for assets on a host will be queued by the browser.

Bundling:

As mentioned Bundling is a new feature in ASP.NET 4.5 and that can be implemented in ASP.NET 4.0 version as well with the help of System.Web.Optimization framework and that makes it easy to combine or bundle multiple files into a single file.

You can create CSS, JavaScript and other bundles. Fewer files means fewer HTTP requests and that can improve first page load performance.


Minification:


Minification performs optimization to website CSS styles and Javascript code, such as removing unnecessary white space and comments and shortening variable names to one character. 

Consider the following JavaScript function.

<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"> loadDropDownValues = function (lookup) { ///&lt;signature&gt; ///&lt;summary&gt; makes a webservice call and bind data to dropdown // &lt;/summary&gt; //&lt;!--data-blogger-escaped-&amp;lt;param name=&amp;quot;Lookup&amp;quot; type=&amp;quot;String&amp;quot; /&amp;gt;--&gt;Lookup table name for dropdown ///&lt;/signature&gt; Your code goes here }</span>
After minification it removes unwanted comments and shortens the variable names, the function is reduced to the following:

<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"> loadDropDownValues = function (l) {your code goes here}; </span>
<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"><br /></span> <span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"><br /></span>

Bundling and Minification Impact in Web Sites



The following table shows several important differences between listing all the assets individually and using bundling and minification (B/M) in the sample program. 


Following table is for representation and shows the impact of B&M in Web Applications.




Using B/M Without B/M Change
File Requests 9 34 256%
KB Sent 3.36 11.92 266%
KB Received 388.51 530 36%
Load Time 510 MS 780 MS 53%


Bundling and Minification Implementation:

It is very easy to implement B&M in our web applications. 

This can be enabled or disabled by setting the value of the debug attribute in the compilation Element in the Web.config file. 

 In the following XML, disable the bundling and minification by setting debug to true.

<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"> &lt;system data-blogger-escaped-.web=""&gt; &lt;compilation data-blogger-escaped-debug="true"&gt; Lines removed for clarity. &lt;/compilation&gt;&lt;/system&gt;.</span>

<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"></span>In order to enable bundling and minification, set the debug value to "false".

 We can override the Web.config setting with the EnableOptimizations property on the BundleTable class too.


Note: Please note that Unless EnableOptimizations is true or the debug attribute in the compilation Element in the Web.config file is set to false, files will not be bundled or minified.

Additionally, the .min version of files will not be used, the full debug versions will be selected.EnableOptimizations overrides the debug attribute in the compilation Element in the Web.config file.


If you are using .net 4.0 versions then we need to install the System.Web.Optimizatin framework from Nugget Package Manager Tool. It Installs Other Dependent DLL’s like WebGreese.DLL.



Practical Approach to Implement Bundling and Minification:

In my case I have created a separate file for listing all resources (Including CSS, JS) in XML format.
Take a look at the sample of xml file below.

<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"> &lt;bundling&gt; &lt;js data-blogger-escaped-name="~/BlankMaster.js"&gt; &lt;path&gt;~/Scripts/jquery-1.10.2.js&lt;/path&gt; &lt;path&gt;~/Scripts/jquery-ui-1.10.4.custom.js&lt;/path&gt; &lt;path&gt;~/Scripts/CommonFunctions.js&lt;/path&gt; &lt;path&gt;~/Scripts/jquery.tablednd.js&lt;/path&gt; &lt;/js&gt; &lt;css data-blogger-escaped-name="~/BlankMaster.css"&gt; &lt;path&gt;~/Styles/jquery-ui-1.10.4.custom.css&lt;/path&gt; &lt;path&gt;~/Jqx/Jqx - CSS/jqx.base.css&lt;/path&gt; &lt;path&gt;~/Jqx/Jqx - CSS/jqx.metro.css&lt;/path&gt; &lt;path&gt;~/Styles/Main.css&lt;/path&gt; &lt;/css&gt; &lt;js data-blogger-escaped-name="~/MasterPage.js"&gt; &lt;path&gt;~/Scripts/jquery.js&lt;/path&gt; &lt;path&gt;~/Scripts/CommonFunctions.js&lt;/path&gt; &lt;path&gt;~/Scripts/jquery.tablednd.js&lt;/path&gt; &lt;path&gt;~/Scripts/clsCAPS.js&lt;/path&gt; &lt;/js&gt; &lt;css data-blogger-escaped-name="~/MasterPage.css"&gt; &lt;path&gt;~/Styles/Main.css&lt;/path&gt; &lt;/css&gt; &lt;/bundling&gt;</span>


<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"></span>Created one helper class which reads the resource URL’s from xml file which is shown above.

 This Class reads xml file and adds js/css files to bundle using bundle classes referenced from Optimization framework.

The following code enables bundling and minification and overrides any setting in the Web.config file.


<span style="font-family: &quot;georgia&quot; , &quot;times new roman&quot; , serif;"> public void AddBundling() { string filePath = String.Empty; string bundleName = String.Empty; try { StreamReader reader = new StreamReader(HttpContext.Current.Server.MapPath("~/Bundle/FileBundling.xml")); XmlSerializer serializer = new XmlSerializer(typeof(Bundling)); Bundling bundlingInfo = (Bundling)serializer.Deserialize(reader); reader.Close(); reader.Dispose(); #region Bundling of the css files. Bundle cssBundle; foreach (Css css in bundlingInfo.Css) { cssBundle = new StyleBundle(css.Name); foreach (string cssFile in css.Path) { cssBundle.Include(cssFile); } BundleTable.Bundles.Add(cssBundle); } #endregion #region Bundling of the java script files. Bundle jsBundle; foreach (Js js in bundlingInfo.Js) { bundleName = js.Name; jsBundle = new ScriptBundle(js.Name); foreach (string jsFile in js.Path) { filePath = jsFile; jsBundle.Include(jsFile); } BundleTable.Bundles.Add(jsBundle); } #endregion BundleTable.EnableOptimizations = true; } catch (Exception ex) { throw new Exception("There is a problem while creating Bundle", ex); } } </span> To identify individual nodes in xml file one model class created with properties which map to nodes in xml file. This Class Represents Model Class which maps to nodes added in xml file.

[Serializable] public class Js { [XmlAttribute] public string Name { get; set; } [XmlElement] public string[] Path { get; set; } } public class Css { [XmlAttribute] public string Name { get; set; } [XmlElement] public string[] Path { get; set; } } [Serializable] public class Bundling { [XmlElement] public Js[] Js { get; set; } [XmlElement] public Css[] Css { get; set; } }

Bundling and Minification will be registered from Global.asax file. In order to enable bundling and minifaction we have to register functionality in global.asax file. In Global.asax Applicatin_Start() method.Create the object of helper class which we created for bundling and minification.

ApplicationSettingsHelper appSettings = new ApplicationSettingsHelper(); appSettings.AddBundling(); Next step is how to call Bundled resources in webpage/Master pages Following are the syntaxes to load bundled files(CSS, JS) in webpages I have called bundled files in master pages as follows Bundles are referenced in views/aspx using the Render method, (Styles. Render for CSS and Scripts. Render for JavaScript). The following markup from the Master Pages shows how Navigator Pages reference CSS and JavaScript bundles.


BlankMaster.Master:


&lt;%# System.Web.Optimization.Styles.Render("~/Common.css") %&gt; &lt;%# System.Web.Optimization.Scripts.Render("~/BlankMaster.js")%&gt;

MasterPage Master:


&lt;%#System.Web.Optimization.Styles.Render("~/MasterPage.css") %&gt; &lt;%# System.Web.Optimization.Scripts.Render("~/MasterPage.js")%&gt;

Comments

Popular posts from this blog

How to Capture Image using web camera in Asp.net and C#.NET / VB.NET

How to add your .net application to git hub repository

Download Excel File using AJAX in JavaScript