Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/renatomarinho/laravel-page-speed
Package to optimize your site automatically which results in a 35%+ optimization
https://github.com/renatomarinho/laravel-page-speed
blade-template laravel laravel-5-package laravel-blade-minify laravel-package minify-html page-speed
Last synced: 1 day ago
JSON representation
Package to optimize your site automatically which results in a 35%+ optimization
- Host: GitHub
- URL: https://github.com/renatomarinho/laravel-page-speed
- Owner: renatomarinho
- License: mit
- Created: 2017-09-10T01:41:07.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-08-12T16:50:42.000Z (5 months ago)
- Last Synced: 2025-01-14T02:03:20.913Z (8 days ago)
- Topics: blade-template, laravel, laravel-5-package, laravel-blade-minify, laravel-package, minify-html, page-speed
- Language: PHP
- Homepage:
- Size: 211 KB
- Stars: 2,433
- Watchers: 77
- Forks: 285
- Open Issues: 46
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Laravel Page Speed
Simple package to minify HTML output on demand which results in a 35%+ optimization. Laravel Page Speed was created by [Renato Marinho][link-author], and currently maintained by [João Roberto P. Borges][link-maintainer], [Lucas Mesquita Borges][link-maintainer-2] and [Renato Marinho][link-author].
## Installation
> **Requires:**
- **[PHP 7.2.5+](https://php.net/releases/)**
- **[Laravel 6.0+](https://github.com/laravel/laravel)**You can install the package via composer:
```sh
composer require renatomarinho/laravel-page-speed
```This package supports Laravel [Package Discovery][link-package-discovery].
### Publish configuration file
`php artisan vendor:publish --provider="RenatoMarinho\LaravelPageSpeed\ServiceProvider"`
## Do not forget to register middlewares
Next, the `\RenatoMarinho\LaravelPageSpeed\Middleware\CollapseWhitespace::class` and other middleware must be registered in the kernel, for example:
```php
//app/Http/Kernel.phpprotected $middleware = [
...
\RenatoMarinho\LaravelPageSpeed\Middleware\InlineCss::class,
\RenatoMarinho\LaravelPageSpeed\Middleware\ElideAttributes::class,
\RenatoMarinho\LaravelPageSpeed\Middleware\InsertDNSPrefetch::class,
\RenatoMarinho\LaravelPageSpeed\Middleware\RemoveComments::class,
//\RenatoMarinho\LaravelPageSpeed\Middleware\TrimUrls::class,
//\RenatoMarinho\LaravelPageSpeed\Middleware\RemoveQuotes::class,
\RenatoMarinho\LaravelPageSpeed\Middleware\CollapseWhitespace::class, // Note: This middleware invokes "RemoveComments::class" before it runs.
\RenatoMarinho\LaravelPageSpeed\Middleware\DeferJavascript::class,
]
```## Middlewares Details
### \RenatoMarinho\LaravelPageSpeed\Middleware\RemoveComments::class
The **RemoveComments::class** filter eliminates HTML, JS and CSS comments.
The filter reduces the transfer size of HTML files by removing the comments. Depending on the HTML file, this filter can significantly reduce the number of bytes transmitted on the network.### \RenatoMarinho\LaravelPageSpeed\Middleware\CollapseWhitespace::class
The **CollapseWhitespace::class** filter reduces bytes transmitted in an HTML file by removing unnecessary whitespace.
This middleware invoke **RemoveComments::class** filter before executation.> **Note**: Do not register the "RemoveComments::class" filter with it. Because it will be called automatically by "CollapseWhitespace::class"
#### Before
![Before of Laravel Page Speed][link-before]
#### After
![After of Laravel Page Speed][link-after]
### \RenatoMarinho\LaravelPageSpeed\Middleware\RemoveQuotes::class
The **RemoveQuotes::class** filter eliminates unnecessary quotation marks from HTML attributes. While required by the various HTML specifications, browsers permit their omission when the value of an attribute is composed of a certain subset of characters (alphanumerics and some punctuation characters).
Quote removal produces a modest savings in byte count on most pages.
### \RenatoMarinho\LaravelPageSpeed\Middleware\ElideAttributes::class
The **ElideAttributes::class** filter reduces the transfer size of HTML files by removing attributes from tags when the specified value is equal to the default value for that attribute. This can save a modest number of bytes, and may make the document more compressible by canonicalizing the affected tags.
### \RenatoMarinho\LaravelPageSpeed\Middleware\InsertDNSPrefetch::class
The **InsertDNSPrefetch::class** filter Injects tags in the HEAD to enable the browser to do DNS prefetching.
DNS resolution time varies from <1ms for locally cached results, to hundreds of milliseconds due to the cascading nature of DNS. This can contribute significantly towards total page load time. This filter reduces DNS lookup time by providing hints to the browser at the beginning of the HTML, which allows the browser to pre-resolve DNS for resources on the page.
### ⚠️ \RenatoMarinho\LaravelPageSpeed\Middleware\TrimUrls::class,
The **TrimUrls::class** filter trims URLs by resolving them by making them relative to the base URL for the page.
> **Warning**: **TrimUrls::class** is considered **medium risk**. It can cause problems if it uses the wrong base URL. This can happen, for example, if you serve HTML that will be pasted verbatim into other HTML pages. If URLs are trimmed on the first page, they will be incorrect for the page they are inserted into. In this case, just disable the middleware.
### \RenatoMarinho\LaravelPageSpeed\Middleware\InlineCss::class
The **InlineCss::class** filter transforms the inline "style" attribute of tags into classes by moving the CSS to the header.
### \RenatoMarinho\LaravelPageSpeed\Middleware\DeferJavascript::class
Defers the execution of javascript in the HTML.
> If necessary cancel deferring in some script, use `data-pagespeed-no-defer` as script attribute to cancel deferring.
## Configuration
After installing package, you may need to configure some options.
### Disable Service
You would probably like to set up the local environment to get a readable output.
```php
//config/laravel-page-speed.php//Set this field to false to disable the laravel page speed service.
'enable' => env('LARAVEL_PAGE_SPEED_ENABLE', true),
```
### Skip routesYou would probably like to configure the package to skip some routes.
```php
//config/laravel-page-speed.php//You can use * as wildcard.
'skip' => [
'*.pdf', //Ignore all routes with final .pdf
'*/downloads/*',//Ignore all routes that contain 'downloads'
'assets/*', // Ignore all routes with the 'assets' prefix
];
```By default this field comes configured with some options, so feel free to configure according to your needs...
> *Notice*: This package skip automatically 'binary' and 'streamed' responses. See [File Downloads][link-file-download].
## Testing
```sh
$ composer test
```## Contributing
Please see [CONTRIBUTING](CONTRIBUTING.md) for details.
## Contributors
- [Caneco](https://twitter.com/caneco) (for the logo)
- [All Contributors][link-contributors]## Inspiration
#### Mod Page Speed (https://www.modpagespeed.com/)
## License
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.
[link-before]: https://i.imgur.com/cN3MWYh.png
[link-after]: https://i.imgur.com/IKWKLkL.png
[link-author]: https://github.com/renatomarinho
[link-maintainer]: https://github.com/joaorobertopb
[link-maintainer-2]: https://github.com/lucasMesquitaBorges
[link-contributors]: ../../contributors
[link-file-download]: https://laravel.com/docs/6.0/responses#file-downloads
[link-package-discovery]: https://laravel.com/docs/6.0/packages#package-discovery