Start using ES6 with Rails today
… and check why 5600+ Rails engineers read also this
Start using ES6 with Rails today
The thing that made me fond of writing front-end code was CoffeeScript. It didn’t drastically change syntax. Coffee introduced many features that made my life as a web developer much easier (e.g. destruction and existential operators). That was a real game changer for Rails developers. We can write our front-end in language that is similar to Ruby and defends us from quirks of JavaScript.
Fortunately the TC39 committee is working hard on sixth version of ECMAScript. You can think about it as an improved JavaScript. It added many features, many of which you may have already seen on CoffeeScript. You can read about some goodies added to ES6 in this blogpost.
The best part of ES6 is that you can use it, despite the fact it hasn’t been finished yet.
How can I use ES6 in my web browser?
New features of ES6 can be emulated in JavaScript (used in our web browsers) using Babel. It provides full compatibility. However one of the features may require some extra work.
One of most exciting features of ES6 are built-in modules. Before ES6 we used solutions like CommonJS or RequireJS. By default Babel uses CommonJS modules as a fallback. If you didn’t use any type of packaging and want to use one, you will need to setup one.
Bringing ES6 to Rails
Sprockets 4.x promise to bring ES6 transpiling out of the box. This release doesn’t seem to come up soon, so we need to find some way around.
Using Sprockets with sprockets-es6
gem
On babel website we can find link to sprockets-es6
gem, which enables ES6 transpiling for sprockets. Unfortunately it does not come without problems - the gem requires sprockets
in version ~3.0.0.beta
. By default babel converts ES6 modules to CommonJS modules. Two gems providing CommonJS (browserify-rails
and sprockets-commonjs
) requires sprockets
to be in version lower than 3.0.0.
You can try using other gem to get JavaScript packaging like requirejs-rails gem. Remember to register ES6 module transformer with valid option in Sprockets. See this test file for example usage.
If you decide to go with this method, you just need to put these two files in Gemfile.
gem 'sprockets', '>=3.0.0.beta'
gem 'sprockets-es6'
And now run bundle install
. After installation you can write your ES6 code in files with .es6
extension.
Using Node.JS with Gulp
Marcin wrote some time ago about unusual approach for asset serving in Rails applications. We can completely remove sprockets and do it on our own with simple Node.js application.
We want to remove any dependencies on Sprockets or any other Ruby gem, when it comes to asset serving. Moreover, using this method, we get faster overall asset compiling than with Sprockets.
With Gulp, we can use babelify
and browserify
node packages in our asset processing process. It let us to use all ES6 features without any inconvenience. You can see example Gulpfile.js with ES6 transpiling and SASS compiling on gist: Gulpfile.js
Conclusions
There are many more workarounds to get ES6 in Rails environment that doesn’t require discarding Sprockets. Unfortunately none of them are good enough to mention as production-ready. I strongly recommend going with Gulp. It’s simple, powerful and provides native environment to work with assets.
If you don’t want to switch from Sprockets, you can try-out sprockets-es6
gem.
If you want to receive more articles about Rails and front-end, sign-up for our newsletter below.