Skip to main content Skip to footer

How to use bundling and minification with Umbraco V9

In older versions of Umbraco (V8 and prior) you could use bundles within the ASP.NET Web Optimization Framework from the .NET Framework to optimise your css and javascript assets.

This worked well, and made managing these items quick and easy.

In .NET 5+ the BuildBundlerMinifier is no longer available, instead we need to generate these files another way, I personally use gulp for this.

A quick start for this, is to install the Bundler & Minifier Visual Studio extension, once you have installed this extension restart Visual Studio.

Next create a file called bundleconfig.json in the root of your web project, and paste in the following code (replacing the links to the assets to your own):

Right click on the bundleconfig.json file, then hover over Bundler & Minifier, and then click on the Convert to Gulp option

Convert Bundler & Minifier to Gulp

This will create a gulpfile.js, you can now remove the Bundler & Minifier Visual Studio extension.

Before you can create the minified files with gulp, you will need to install the packages with the following command:

npm install

You can now run the following command to build the minified files:

gulp min

At this point I recommend excluding the minified files from your source control by adding the following line to your .gitignore

**/wwwroot/bundles

Next you can clean up the bundleconfig.json file created earlier by removing the minify and sourceMap sections.

 

 

 To configure your views to use the new files you will need to use the BundlerMinifier.TagHelpers which can be installed with the following NuGet package:

dotnet add package BundlerMinifier.TagHelpers

You will want to enable the cache busting querystring, you can do this by adding the following to the ConfigureServices in startup.cs

services.AddBundles(options =>
{
    options.AppendVersion = true;
});

Once installed you will need to add the following line to your _ViewImports.cshtml file to make the tag helper accessible:

@addTagHelper *, BundlerMinifier.TagHelpers

Finally in your views containing the links to your css and scripts files, you can replace them with the following:

<bundle name="wwwroot/bundles/site.min.css" />

When you are in debug mode it will generate seperate links to your files:

<link href="/lib/bootstrap/dist/css/bootstrap.css" rel="stylesheet" />
<link href="/css/site.css" rel="stylesheet" />

When your running in release mode it will bundle your assets and append a cachebusting querystring:

<link href="/bundles/site.min.css?v=Hr2K_e4FFmONl0h--fZbjZJrI6JwyQ7kHuXgHE85RxM" rel="stylesheet" />

About the author

Aaron Sadler

Aaron Sadler, Umbraco MVP (2x), Umbraco Certified Master Developer and DevOps Engineer

comments powered by Disqus