webpack managed assets
Nikola Đuza
Semaphore ❤️ Rails Semaphore ❤️ JavaScript
language.history(📚)
- Ruby -1995
- JavaScript -1995
- Rails - 2004
- React - 2013
language.history(Rails, JS)
- Unobtrusive JavaScript - Rails 3.0
- Asset Pipeline - Rails 3.1
- Webpack/React/Angular/Vue.js out of the box - Rails 5.1
Unobtrusive JS
<%= link_to "an article", @article, remote: true %>
<a href="/articles/1" data-remote="true">an article</a>
$ ->
$("a[data-remote]").on "ajax:success", (e, data, status, xhr) ->
alert "The article was deleted."
Asset pipeline
The first feature of the pipeline is to concatenate assets, which can reduce the number of requests that a browser makes to render a web page.
Asset pipeline
The second feature of the asset pipeline is asset minification or compression.
Asset pipeline
The third feature of the asset pipeline is it allows coding assets via a higher-level language, with precompilation down to the actual assets.
I: I want to use lodash.
AP: It's easy, use rails-assets or just include the file in the pipeline by hand.
I: Awesome, thanks 🍺.
gem "rails-assets-lodash", "~> 2.4.1"
I: Hey, I want to use enzyme to test React.
AP: OK, did you try rails-assets?
I: Yeah, it's not on there 😔.
AP: And did you try including the file in the pipeline?
I: Yep, but it's too big, and they don't serve minfied version 😢.
AP: ¯\_(ツ)_/¯
node package manager
- released in 2010.
- package.json
browserify-rails 💎
- simple to use
- supports modules
- works with Asset Pipeline
problem with browserify-rails
- slow asset compilation on CI/CD
- slow asset compilation in development
- slow asset compilation in tests
webpacker 💎
- latest and gratest
- yarn
- React support
browserify-rails vs webpacker
Asset compilation went from 11 minutes to 1 minute.
browserify-rails vs webpacker
Cucumber scenarios went from ~5 minutes to ~2 minutes.
browserify-rails vs webpacker
Minified application.js went from ~8 MB to ~4.5 MB
Webpack Managed Assets
By Nikola Đuza
Webpack Managed Assets
Brief history of how Semaphore got to using webpack to manage assets.
- 1,191