.NET HELP

WebGrease .NET Core (How It Works For Developers)

Updated August 13, 2024
Share:

Introduction

WebGrease's integration with IronPDF and .NET Core offers a potent method for producing PDF documents of excellent quality and streamlining web application performance. With the use of JavaScript compression, image optimization, and CSS minification, WebGrease is a feature-rich package that makes websites run quicker and smoother for developers. Developers can easily create dynamic PDFs from several sources, including HTML and MVC views when they use IronPDF, a powerful .NET toolkit for producing and manipulating PDF documents.

Web applications are kept fluid and adaptable with this integration, which enables effective resource management and dynamic PDF generation. WebGrease and IronPDF are fully compatible with .NET Core, allowing developers to create cross-platform applications that function flawlessly on Linux, macOS, and Windows. This results in an enhanced user experience thanks to optimized performance and superior document handling.

What is WebGrease?

Originally created as a component of the ASP .NET stack, WebGrease is a tool for automating processes such as optimizing JavaScript, compression, picture optimization, and CSS minification of static files in order to improve web performance. These optimizations contribute to the reduction of web resource sizes, which improves web application performance and speeds up load times.

WebGrease .NET Core (How It Works For Developers): Figure 1

In the context of .NET Core, when we discuss WebGrease, we mean the application of these optimization methods to .NET Core applications. Microsoft created the cross-platform, open-source .NET Core framework to let developers create cutting-edge, scalable, and high-performing apps. Developers can apply performance optimization techniques from traditional ASP.NET applications to their .NET Core projects by integrating WebGrease. This way, developers can make sure that their web applications are efficient and performant on various platforms, such as Windows, Linux, and macOS.

Features of WebGrease

Within the framework of .NET Core, WebGrease provides a number of capabilities targeted at enhancing the effectiveness and speed of web applications. The salient characteristics are as follows:

CSS Minification:

Eliminates extraneous formatting, comments, and whitespace from CSS files. Reduces HTTP requests by combining numerous CSS files into a single file. Enhances performance and speeds up loading times for CSS.

JavaScript Compression:

Minimizes JavaScript files by removing characters that aren't needed. Makes a single JavaScript file out of several separate ones. Minimizes JavaScript files' size to expedite download and execution times.

Image Optimization:

Reduces file size by compressing images without noticeably compromising quality. When appropriate, convert photos to more efficient formats. Increases loading speeds through image resource optimization.

HTML Minification:

Reduces the amount of whitespace and comments in HTML files. Simplifies HTML files so that browsers can parse and render them more quickly.

Resource Bundling:

Combines several JavaScript and CSS files into a single, streamlined file. Improves load times by lowering the quantity of HTTP requests required to get load file, get static files, and load a page.

Configuration Flexibility:

Offers choices for configuring the optimization process. Gives developers the option to choose which directories and files to optimize or leave out.

Cross-Platform Compatibility:

Completely compatible with .NET Core, enabling use in Windows, Linux, and macOS apps. Guarantees that performance improvements work well in a variety of settings.

Integration with Build Processes:

Able to be incorporated into build procedures to optimize system resources automatically during deployment and development. Supports automated processes to ensure consistent optimization of the system, at various development phases.

Improved Performance:

Minimizes the amount of resources that must be loaded, thereby improving the performance of the entire web application. Enhances user experience and speeds up the loading of pages.

Create and Config WebGrease

A .NET Core application must install the required packages, configure the build process, and set up optimization tasks before WebGrease can be used. The following steps will help you establish and set up WebGrease in a .NET Core application:

Create a .NET Core Project

Make a new .NET Core web application first. To accomplish this, you can use the .NET CLI.

dotnet new web -n WebGreaseApp
cd WebGreaseApp
dotnet new web -n WebGreaseApp
cd WebGreaseApp
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Add Required Packages

Although there isn't a direct .NET Core package for WebGrease, you can still accomplish comparable functionality with other programs like BundlerMinifier. Include this bundle in your undertaking.

dotnet add package BundlerMinifier.Core
dotnet add package BundlerMinifier.Core
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Configure Bundling and Minification

Make a bundleconfig.json file in your project root to provide the bundling and minification settings for your CSS and JavaScript files. This is an illustration of a configuration.

[
  {
    "outputFileName": "wwwroot/css/site.min.css",
    "inputFiles": [
      "wwwroot/css/site.css"
    ],
    "minify": {
      "enabled": true,
      "renameLocals": true
    }
  },
  {
    "outputFileName": "wwwroot/js/site.min.js",
    "inputFiles": [
      "wwwroot/js/site.js"
    ],
    "minify": {
      "enabled": true
    }
  }
]
[
  {
    "outputFileName": "wwwroot/css/site.min.css",
    "inputFiles": [
      "wwwroot/css/site.css"
    ],
    "minify": {
      "enabled": true,
      "renameLocals": true
    }
  },
  {
    "outputFileName": "wwwroot/js/site.min.js",
    "inputFiles": [
      "wwwroot/js/site.js"
    ],
    "minify": {
      "enabled": true
    }
  }
]
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Integrate with the Build Process

Add instructions for executing the bundling and minification operations during the build process to your project file (.csproj).

In your .csproj file, add the following element inside the element:

<Target Name="PrepublishScript" BeforeTargets="PrepareForPublish">
  <Exec Command="dotnet bundle" />
</Target>
<Target Name="PrepublishScript" BeforeTargets="PrepareForPublish">
  <Exec Command="dotnet bundle" />
</Target>
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Install and Run BundlerMinifier

You must install the .NET utility in order to utilize the BundlerMinifier tool, as we have included it. Execute the subsequent command line below:

dotnet tool install -g BundlerMinifier.Core
dotnet tool install -g BundlerMinifier.Core
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

To bundle and minify your files, run:

dotnet bundle
dotnet bundle
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Optimize Images

You can use ImageSharp or other .NET Core-compliant image optimization tools for picture optimization.

Install ImageSharp

Install the SixLabors.ImageSharp package:

dotnet add package SixLabors.ImageSharp
dotnet add package SixLabors.ImageSharp
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Here is an example of a code snippet for picture optimization:

using SixLabors.ImageSharp;
using SixLabors.ImageSharp.Processing;
using System.IO;
public void OptimizeImage(string inputPath, string outputPath)
{
    using (var image = Image.Load(inputPath))
    {
        image.Mutate(x => x.Resize(new ResizeOptions
        {
            Mode = ResizeMode.Max,
            Size = new Size(800, 600)
        }));
        image.Save(outputPath); // Automatic encoder selected based on file extension.
    }
}
using SixLabors.ImageSharp;
using SixLabors.ImageSharp.Processing;
using System.IO;
public void OptimizeImage(string inputPath, string outputPath)
{
    using (var image = Image.Load(inputPath))
    {
        image.Mutate(x => x.Resize(new ResizeOptions
        {
            Mode = ResizeMode.Max,
            Size = new Size(800, 600)
        }));
        image.Save(outputPath); // Automatic encoder selected based on file extension.
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Run your application one last time to make sure bundling and minification are operating as intended.
Open your application in the browser, then make sure the JavaScript and CSS files are minified by looking at them.

With tools that work with the current .NET environment, you may set up and configure WebGrease-like optimization for a.NET Core application by following these steps.

Getting Started with IronPDF

Setting up performance optimization for your web resources and using IronPDF for PDF generation and manipulation are both necessary for integrating WebGrease-like optimization with IronPDF in a .NET Core application. Here's how to get started, step-by-step:

What is IronPDF?

The feature-rich .NET library IronPDF allows C# programs to produce, read, and edit PDF documents. With this program, developers can easily convert HTML, CSS, and JavaScript information into high-quality, print-ready PDFs. Among the most crucial tasks are adding headers and footers, dividing and combining PDFs, adding watermarks to documents, and converting HTML to PDF.

IronPDF is helpful for a variety of applications because it supports both .NET Framework and .NET Core. Because PDFs are user-friendly and include extensive content, developers may easily incorporate them into their products. Because IronPDF can handle complex data layouts and formatting, the PDFs it generates as an output closely mirror the HTML text that was originally provided by the client.

WebGrease .NET Core (How It Works For Developers): Figure 2

Features of IronPDF

PDF Generation from HTML

Convert JavaScript, HTML, and CSS to PDF. Supports media queries and responsive design, two contemporary web standards. Useful for dynamically decorating PDF documents, reports, and bills using HTML and CSS

PDF Editing

Pre-existing PDFs can have text, photos, and other content added to them. Take text and pictures out of PDF files. Combine numerous PDFs into one single file. Divide PDF files into multiple separate documents. Include watermarks, annotations, headers, and footers.

PDF Conversion

Convert a wide range of file formats to PDF, including Word, Excel, and picture files. Allows PDF to image conversion (PNG, JPEG, etc.).

Performance and Reliability

High performance and dependability are desired design qualities in industrial settings. Manages big document sets with ease.

Install IronPDF

To gain the tools you need to work with PDFs in .NET projects, install the IronPDF package.

dotnet add package IronPdf
dotnet add package IronPdf
'INSTANT VB TODO TASK: The following line uses invalid syntax:
'dotnet add package IronPdf
VB   C#

Configure Bundling and Minification

Make a bundleconfig.json config file in your project root to provide the bundling and minification settings for your CSS and JavaScript files. This config file is an illustration of a configuration:

[
  {
    "outputFileName": "wwwroot/css/site.min.css",
    "inputFiles": [
      "wwwroot/css/site.css"
    ],
    "minify": {
      "enabled": true,
      "renameLocals": true
    }
  },
  {
    "outputFileName": "wwwroot/js/site.min.js",
    "inputFiles": [
      "wwwroot/js/site.js"
    ],
    "minify": {
      "enabled": true
    }
  }
]
[
  {
    "outputFileName": "wwwroot/css/site.min.css",
    "inputFiles": [
      "wwwroot/css/site.css"
    ],
    "minify": {
      "enabled": true,
      "renameLocals": true
    }
  },
  {
    "outputFileName": "wwwroot/js/site.min.js",
    "inputFiles": [
      "wwwroot/js/site.js"
    ],
    "minify": {
      "enabled": true
    }
  }
]
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Connect to the Building Process

Make sure that the instructions for executing the minification and bundling operations during the build process are included in your project file (.csproj). In your .csproj file, add the element that follows within the element:

<Target Name="PrepublishScript" BeforeTargets="PrepareForPublish">
  <Exec Command="dotnet bundle" />
</Target>
<Target Name="PrepublishScript" BeforeTargets="PrepareForPublish">
  <Exec Command="dotnet bundle" />
</Target>
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Integrate IronPDF

Build a controller with IronPDF to produce PDFs. Create a new PdfController controller.

using Microsoft.AspNetCore.Mvc;
using IronPdf;
namespace WebGreaseIronPdfApp.Controllers
{
    public class PdfController : Controller
    {
        public IActionResult GeneratePdf()
        {
            // Create a PDF from a simple HTML string
            var renderer = new ChromePdfRenderer();
            var pdf = renderer.RenderHtmlAsPdf("<h1>Hello, IronPDF!</h1><p>This is a generated PDF document.</p>");
            // Save the PDF to a byte array
            var pdfBytes = pdf.BinaryData;
            // Return the PDF file as a download
            return File(pdfBytes, "application/pdf", "example.pdf");
        }()
}
using Microsoft.AspNetCore.Mvc;
using IronPdf;
namespace WebGreaseIronPdfApp.Controllers
{
    public class PdfController : Controller
    {
        public IActionResult GeneratePdf()
        {
            // Create a PDF from a simple HTML string
            var renderer = new ChromePdfRenderer();
            var pdf = renderer.RenderHtmlAsPdf("<h1>Hello, IronPDF!</h1><p>This is a generated PDF document.</p>");
            // Save the PDF to a byte array
            var pdfBytes = pdf.BinaryData;
            // Return the PDF file as a download
            return File(pdfBytes, "application/pdf", "example.pdf");
        }()
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

The first thing we do in the PdfController code is import the required namespaces, which are Microsoft.AspNetCore.Mvc for ASP.NET Core MVC functionality and IronPDF for PDF generation. Because it derives from Controller, the PdfController class is an MVC controller. The GeneratePdf method in this class is defined to manage the creation of PDFs.

WebGrease .NET Core (How It Works For Developers): Figure 3

To convert HTML material into a PDF, this function creates an instance of IronPDF's ChromePdfRenderer(). A basic HTML string can be transformed into a PDF document using the RenderHtmlAsPdf function. The BinaryData attribute is then used to save this PDF to a byte array. Lastly, the PDF file is returned as a downloadable response using the File method, along with the requested filename (example.pdf) and the correct MIME type (application/pdf). The program can now dynamically create and serve PDF documents, based on HTML content thanks to this integration.

Route to Generate PDF

Make sure that the PDF generation routing is included in your Startup.cs file.

public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    if (env.IsDevelopment())
    {
        app.UseDeveloperExceptionPage();
    }
    else
    {
        app.UseExceptionHandler("/Home/Error");
        app.UseHsts();
    }
    app.UseHttpsRedirection();
    app.UseStaticFiles();
    app.UseRouting();
    app.UseAuthorization();
    app.UseEndpoints(endpoints =>
    {
        endpoints.MapControllerRoute(
            name: "default",
            pattern: "{controller=Home}/{action=Index}/{id?}");
        endpoints.MapControllerRoute(
            name: "pdf",
            pattern: "pdf",
            defaults: new { controller = "Pdf", action = "GeneratePdf" });
    });
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    if (env.IsDevelopment())
    {
        app.UseDeveloperExceptionPage();
    }
    else
    {
        app.UseExceptionHandler("/Home/Error");
        app.UseHsts();
    }
    app.UseHttpsRedirection();
    app.UseStaticFiles();
    app.UseRouting();
    app.UseAuthorization();
    app.UseEndpoints(endpoints =>
    {
        endpoints.MapControllerRoute(
            name: "default",
            pattern: "{controller=Home}/{action=Index}/{id?}");
        endpoints.MapControllerRoute(
            name: "pdf",
            pattern: "pdf",
            defaults: new { controller = "Pdf", action = "GeneratePdf" });
    });
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
VB   C#

Run and Verify

Run your application to ensure that you can create PDFs and that the bundling and minification are functioning properly.

dotnet run
dotnet run
'INSTANT VB TODO TASK: The following line uses invalid syntax:
'dotnet run
VB   C#

Open the browser and navigate to your application. It should be possible for you to create a single file and download a PDF document by going to //pdf.

Conclusion

IronPDF and WebGrease-like optimization combined provide a potent combo for improving online performance and producing high-quality PDF documents in .NET Core applications. Developers may make sure their apps are effective and flexible by using tools like IronPDF for creating PDFs and BundlerMinifier for optimizing resources. In addition to picture compression, resource optimization strategies like CSS and JavaScript minification also help to speed up page loads and enhance user experience. Concurrently, IronPDF has strong capabilities for dynamically creating PDFs from HTML text, simplifying the process of creating properly prepared documents like invoices, reports, and more.

This integration provides a complete solution for contemporary web development needs within the .NET Core framework, not only improving online application performance but also adding useful features for processing PDFs.

With IronPDF and IronSoftware, you can increase your toolkit for .NET development by taking use of OCR, barcode scanning, PDF creation, Excel connectivity, and much more. For a starting price of $749, IronPDF gives developers access to more web apps and features as well as more effective development. To do this, it combines its core concepts with the very flexible Iron Software toolbox.

Developers will find it easy to select the optimal model if the project's license alternatives are well-defined. The previously mentioned benefits aid in the prompt, well-organized, and efficient execution of solutions by developers for an array of issues.

< PREVIOUS
DuckDB C# (How It Works For Developers)
NEXT >
Azure.Messaging.ServiceBus Example C# (How It Works)

Ready to get started? Version: 2024.9 just released

Free NuGet Download Total downloads: 10,591,670 View Licenses >