Skip to content

Latest commit

 

History

History
57 lines (48 loc) · 2.23 KB

README.md

File metadata and controls

57 lines (48 loc) · 2.23 KB

laravel-elixir-cachebust

A simple laravel-elixir extension that works much like elixir's built in .version() method, except instead of renaming asset file names (and creating duplicates in /public/build/ and polluting your git repo), this module will append the cache-busting string onto the end of a file in the form of query string (i.e. /assets/css/styles?4c6649eb) inside of the the HTML document via use of a custom function.

Installation

While in your laravel root directory, execute the following code:

npm install laravel-elixir-cachebust --save

Usage

Your gulpfile.js needs two modifications in order to work properly.

  • You need to require('laravel-elixir-cachebust'); at the top of the file.
  • Instead of using .version() you can use .cachebust() in a similar way

Example of gulpfile.js

var elixir = require('laravel-elixir');
require('laravel-elixir-cachebust');

elixir(function(mix) {
    mix.sass("styles.scss");
    mix.scripts("app.js");

    mix.cachebust(["styles.css", "app.js"]);
});

Options

The second parameter of .cachebust() allows you to set these options:

  • method: The method used to generate a cache-buster string. Valid options are:
    • "hash" - using a MD4 or MD5 hash cipher. (this is the default option)
    • "uuid" - a randomly generated string.
    • "mtime" - The time that the file was last modified, according to the filesystem.
  • length: The maximum length that a cache-busting string should be. (default is 8)
  • baseDir: The path (relative to laravel's root dir) where the generated json file should be. (default is "public")
  • file: The filename of the json file. (default is "cachbuster.json")

Example of gulpfile.js - With options

var elixir = require('laravel-elixir');
require('laravel-elixir-cachebust');

elixir(function(mix) {
    mix.sass("styles.scss");
    mix.scripts("app.js");

    mix.cachebust(
        ["styles.css", "app.js"],
        {
            method: "uuid",
            length: 10,
            baseDir: "public"   // This is where our assets should be located,
                                // and is where we will generate our json file.
        }
    );
});