The Laravel Elixir version
task appends a unique hash to filename,
allowing for cache-busting.
elixir(function(mix) {
mix.version("css/all.css");
});
For example, the generated file name will look something like:
all-16d570a7.css
.
In Laravel, you can use in your views the elixir()
function to load
the appropriately hashed asset:
<link rel="stylesheet" href="{{ elixir("css/all.css") }}">
This twig extension is an adaptation of this elixir()
function.
You need PHP >= 5.5.9 to use the library, but the latest stable version of PHP is recommended.
Install using Composer:
composer require brieucthomas/elixir-twig-extension
This will edit (or create) your composer.json file and automatically choose the most recent version.
use BrieucThomas\Twig\Extension\ElixirExtension;
$elixir = new ElixirExtension(
$publicDir, // the absolute public directory
$buildDir, // the elixir build directory (default value is 'build')
$manifestName // the manifest filename (default value is 'rev-manifest.json')
);
$twig->addExtension($elixir);
# app/config/services.yml
services:
app.twig_elixir_extension:
class: BrieucThomas\Twig\Extension\ElixirExtension
arguments: ["%kernel.root_dir%/../web/"]
public: false
tags:
- { name: twig.extension }
Here an example of gulpfile.js
to compile and version
the script app/Resources/js/app.js
:
// gulpfile.js
const elixir = require('laravel-elixir');
elixir.config.assetsPath = 'app/Resources';
elixir.config.publicPath = 'web';
elixir.config.appPath = 'src';
elixir.config.viewPath = 'app/Resources/views';
elixir(function(mix) {
// compile scripts to web/js/all.js (default output)
mix.scripts(['app.js']);
// version compiled scripts
mix.version(['js/all.js']);
});
<link rel="stylesheet" href="{{ elixir('css/all.css') }}">
<script src="{{ elixir('js/all.js') }}"></script>
You can surround with the asset
twig extension to make your
application more portable:
<link rel="stylesheet" href="{{ asset(elixir('css/all.css')) }}">
<script src="{{ asset(elixir('js/all.js')) }}"></script>