A lightweight and efficient Laravel middleware package that automatically minifies HTML responses, reducing page size and improving load times. The package intelligently removes unnecessary whitespace, comments, and optimizes your HTML output while preserving functionality.
- Automatic HTML Minification: Minifies HTML responses on-the-fly with zero configuration required
- Smart Detection: Only processes HTML responses, automatically skipping JSON, AJAX requests, and other non-HTML content
- Safe Minification: Preserves content in sensitive elements like
<pre>,<textarea>, and<script>tags - Framework-Aware: Compatible with Livewire, Knockout.js, and other JavaScript frameworks
- Configurable Transformers: Choose which transformations to apply or create custom ones
- Performance Optimized: Minimal overhead with efficient regex-based transformations
- Laravel 10, 11, and 12 Support: Works seamlessly with modern Laravel versions
The package includes three built-in transformers:
- Remove Comments: Strips HTML comments while preserving framework-specific comments (Livewire, Knockout.js)
- Remove Whitespace: Eliminates unnecessary whitespace between tags and multiple spaces
- Trim Scripts: Removes extra whitespace from within
<script>tags
Before Minification:
<!DOCTYPE html>
<html>
<head>
<title>My Page</title>
<!-- This is a comment -->
</head>
<body>
<div class="container">
<h1> Welcome </h1>
<script>
console.log('Hello World');
</script>
</div>
</body>
</html>After Minification:
<!DOCTYPE html><html><head><title>My Page</title></head><body><div class="container"><h1>Welcome</h1><script>console.log('Hello World');</script></div></body></html>- PHP 8.2 or higher
- Laravel 10.x, 11.x, or 12.x
Install the package via Composer:
composer require backstage/laravel-minify-html-middlewareThe package will automatically register its service provider.
Publish the configuration file to customize the transformers:
php artisan vendor:publish --tag="laravel-minify-html-middleware-config"This will create a config/minify-html.php file with the following default configuration:
<?php
return [
'transformers' => [
Backstage\MinifyHtml\Transformers\RemoveComments::class,
Backstage\MinifyHtml\Transformers\RemoveWhitespace::class,
Backstage\MinifyHtml\Transformers\TrimScripts::class,
],
];To minify all HTML responses in your application, add the middleware to the global middleware stack in bootstrap/app.php (Laravel 11+):
<?php
use Illuminate\Foundation\Application;
use Illuminate\Foundation\Configuration\Exceptions;
use Illuminate\Foundation\Configuration\Middleware;
use Backstage\MinifyHtml\Middleware\MinifyHtml;
return Application::configure(basePath: dirname(__DIR__))
->withMiddleware(function (Middleware $middleware) {
$middleware->append(MinifyHtml::class);
})
->withExceptions(function (Exceptions $exceptions) {
//
})->create();For Laravel 10, add to app/Http/Kernel.php:
protected $middleware = [
// ...
\Backstage\MinifyHtml\Middleware\MinifyHtml::class,
];To apply minification to specific routes or route groups, register the middleware with an alias:
Laravel 11+ (bootstrap/app.php):
->withMiddleware(function (Middleware $middleware) {
$middleware->alias([
'minify' => \Backstage\MinifyHtml\Middleware\MinifyHtml::class,
]);
})Laravel 10 (app/Http/Kernel.php):
protected $middlewareAliases = [
// ...
'minify' => \Backstage\MinifyHtml\Middleware\MinifyHtml::class,
];Then apply it to specific routes:
Route::get('/dashboard', function () {
return view('dashboard');
})->middleware('minify');
// Or to a group
Route::middleware(['minify'])->group(function () {
Route::get('/about', [AboutController::class, 'index']);
Route::get('/contact', [ContactController::class, 'index']);
});The middleware automatically determines if a response should be minified based on several conditions:
- ✅ Request method is
GETorHEAD - ✅ Response contains HTML (checks
Acceptheader) - ❌ Request is JSON
- ❌ Request is AJAX (XMLHttpRequest)
- ❌ Request is a precognitive request
- ❌ Response has no DOCTYPE declaration in the first 100 characters
This ensures that only actual HTML page responses are minified, avoiding issues with API responses or partial HTML fragments.
You can customize which transformers are applied by modifying the config/minify-html.php file:
<?php
return [
'transformers' => [
// Use only specific transformers
Backstage\MinifyHtml\Transformers\RemoveComments::class,
Backstage\MinifyHtml\Transformers\RemoveWhitespace::class,
// Backstage\MinifyHtml\Transformers\TrimScripts::class, // Disabled
// Add custom transformers
App\HtmlTransformers\CustomTransformer::class,
],
];Remove or comment out any transformer you don't want to use:
<?php
return [
'transformers' => [
// Only remove whitespace, keep comments
Backstage\MinifyHtml\Transformers\RemoveWhitespace::class,
],
];You can create your own HTML transformers by implementing a simple transform method:
<?php
namespace App\HtmlTransformers;
class RemoveMetaTags
{
public function transform(string $html): string
{
// Remove all meta tags
return preg_replace('/<meta[^>]*>/i', '', $html);
}
}Then add it to your configuration:
<?php
return [
'transformers' => [
Backstage\MinifyHtml\Transformers\RemoveComments::class,
Backstage\MinifyHtml\Transformers\RemoveWhitespace::class,
Backstage\MinifyHtml\Transformers\TrimScripts::class,
App\HtmlTransformers\RemoveMetaTags::class,
],
];<?php
namespace App\HtmlTransformers;
class UppercaseTitle
{
public function transform(string $html): string
{
return preg_replace_callback(
'/<title>(.*?)<\/title>/i',
function ($matches) {
return '<title>' . strtoupper($matches[1]) . '</title>';
},
$html
);
}
}Removes HTML comments while preserving special comments needed by frameworks:
// Removes: <!-- This will be removed -->
// Keeps: <!--Livewire--> and <!-- ko --> (Knockout.js)Intelligently removes whitespace while preserving content in:
<pre>tags (preformatted text)<textarea>tags (form inputs)<script>tags (JavaScript code)
The transformer:
- Temporarily hides protected elements
- Removes multiple spaces, tabs, and newlines
- Removes spaces between tags (
> <becomes><) - Restores protected elements
Removes leading and trailing whitespace from within <script> tags without affecting functionality:
<!-- Before -->
<script>
console.log('Hello');
</script>
<!-- After -->
<script>console.log('Hello');</script>HTML minification can reduce your HTML file size by 10-30% on average, depending on your code formatting:
- Faster Page Loads: Smaller HTML files download quicker
- Reduced Bandwidth: Lower data transfer costs
- Improved SEO: Faster page loads contribute to better search rankings
- Better Mobile Experience: Crucial for users on slower connections
Example size reduction:
- Before: 45 KB
- After: 32 KB
- Savings: 28.9% reduction
The package preserves Livewire comments and attributes, ensuring full compatibility:
<!-- Livewire components work perfectly -->
<div wire:model="name">
<!-- Livewire comment preserved -->
</div>Works seamlessly with Inertia.js responses as they are JSON and automatically skipped.
Alpine.js directives and attributes are preserved:
<div x-data="{ open: false }">
<button @click="open = !open">Toggle</button>
</div>- Check your response type: Ensure the response has an
Accept: text/htmlheader - Verify middleware is registered: Confirm the middleware is in your global or route middleware
- Check request method: Only
GETandHEADrequests are processed - DOCTYPE declaration: Make sure your HTML includes
<!DOCTYPE html>early in the response
- Whitespace-dependent CSS: If your layout relies on whitespace between inline elements, add those elements to the
ignoreElementsarray in a custom transformer - Template literals in scripts: Complex JavaScript might need special handling
- Pre-formatted content: Ensure
<pre>and<textarea>tags are being preserved
Temporarily disable transformers one by one to identify which transformation is causing issues:
<?php
return [
'transformers' => [
// Backstage\MinifyHtml\Transformers\RemoveComments::class,
Backstage\MinifyHtml\Transformers\RemoveWhitespace::class,
// Backstage\MinifyHtml\Transformers\TrimScripts::class,
],
];Run the package tests:
composer testRun tests with coverage:
composer test-coverageRun static analysis:
composer analyseFix code style:
composer formatPlease see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.