An example site using Jekyll with Minibundle plugin to fingerprint CSS and JavaScript assets. It's deployed with GitHub Pages at https://tkareine.github.io/jekyll-minibundle-example/.
Sass compiles stylesheets written in SCSS syntax into a single CSS
output file. Minibundle includes the output file of Sass with the
ministamp
Liquid tag into the generated site. The path of the output
file includes the MD5 fingerprint of the file's contents. See
_includes/index/head.html. This
demonstrates how to include the output of an external tool handling
asset compiling, bundling and minifying into Jekyll. The same mechanism
works with JavaScript compilation tools, such as Browserify and
webpack, too. You can use the ministamp
tag to fingerprint any type
of file.
The JavaScript sources in this example demonstrate how to use
Minibundle's minibundle
Liquid block to feed JavaScript source files
to UglifyJS via stdin, read the minified output from
stdout, and include the output file in the generated site. The path of
the output file includes the MD5 fingerprint of the file's contents. See
_includes/scripts/body.html. The bundling
features of minibundle
are really that lightweight, but sometimes
that's just enough.
The compile the site, you'll need Ruby and Node.js programming environments. For Ruby, you'll need Bundler as well.
cd jekyll-minibundle-example
bundle install
npm ci
First, compile Sass source files:
bundle exec rake sass:compile
Alternatively, for more convenient workflow, run Sass in watch mode so
that you'll see the changes in the site when changing .scss
files:
bundle exec rake sass:watch
Open another terminal for running Jekyll. You have the option to run
Minibundle in development mode or without it. In development mode,
there's no asset fingerprinting and files bundled with minibundle
Liquid block appear as is.
To launch Jekyll with Minibundle without development mode:
bundle exec rake jekyll:watch:prod
Alternatively, to launch Jekyll with Minibundle in development mode:
bundle exec rake jekyll:watch:dev
You can view the compiled site at http://localhost:8080/jekyll-minibundle-example/.
To see all the commands available:
bundle exec rake -D