Javascript ES6 + Babel.js + Grunt with Sublime Text

Category:

I’ll show you how to setup a Javascript ES6 workflow with Sublime Text 3. To be able to use ES6 in all browsers we will use Babel.js which is essentially a compiler from ES6 to ES5. We also use Grunt, a javascript task runner, to automate this compilation process.

1. Download Node.js

You need to download node.js for its node package manager (npm). With it we can easily install babel and grunt.

2. Install Grunt CLI

Open a terminal/command prompt and type in:

npm install -g grunt-cli

This will globally install the grunt interface.

3. Install Sublime Package for npm

To use npm from within Sublime Text we need to install the npm package. In Sublime Text hit CTRL + SHIFT + P and type in “Package Control: Install Package”, then type in “npm” and install it. When you hit CTRL + SHIFT + P now you should be able to search for list of npm commands.

4. Create package.json file for your project

Start a new project by creating a new folder. In this root folder create a file called “package.json” with the following contents:

{
  "name": "yourProjectName",
  "version": "0.1.0",
  "devDependencies": {
    "babel-preset-es2015": "^6.6.0",
    "grunt": "^1.0.1",
    "grunt-babel": "^6.0.0",
    "grunt-contrib-copy": "^1.0.0",
    "grunt-contrib-uglify": "^1.0.1"
  },
  "babel": {
    "presets": [
      "es2015"
    ]
  }
}

The package.json file is used by npm to handle all the packages (dependencies) used for your project. (In our case babel, grunt and grunt-plugins.)

5. Install all the dependencies

In sublime go to your folder and hit CTRL + SHIFT + P and execute** “npm: Install Saved Package”**. This will install all the dependencies specified by “devDependencies” in the package.json file.

6. Create gruntfile.js

In your project root folder besides package.json, create a gruntfile.js file with the following contents:

module.exports = function(grunt) {

grunt.initConfig({
    babel: {
        options: {
            "sourceMap": true
        },
        dist: {
            files: [{
                "expand": true,
                "cwd": "src/js",
                "src": ["**/*.jsx"],
                "dest": "src/js-compiled/",
                "ext": "-compiled.js"
            }]
        }
    },
    uglify: {
        all_src : {
            options : {
              sourceMap : true,
              sourceMapName : 'src/build/sourceMap.map'
            },
            src : 'src/js-compiled/**/*-compiled.js',
            dest : 'src/build/all.min.js'
        }
    }
});

    grunt.loadNpmTasks('grunt-babel');
    grunt.loadNpmTasks('grunt-contrib-uglify');
    grunt.registerTask("default", ["babel", "uglify"]);
};

The gruntfile.js file specifies which tasks grunt should automate, here the babel block defines that we want to take all files from “src/js” that end with “.jsx” (written in ES6) and use babel to compile them to ES5 files into “src/js-compiled” with the name extension “-compiled.js”. The source map is specified to still be able to debug these files in ES6. The next command that grunt automates is the “uglify” block which puts all these freshly compiled files from “src/js-compiled” into just a single one named “src/build/all.min.js”.

Folder structure for sublime project with Babel and Grunt

7. Finished: The workflow

You code ES6 javascript files in “src/js” ending with “.jsx”. Then you hit CTRL + SHIFT + P and run “grunt” -> “default” and it will do the automation defined above ending with a single ES5 file in “src/build”.

8. ES6 .jsx syntax highlighting in Sublime Text

You might notice that the .jsx files don’t have the usual .js syntax highlighting. To fix it we need to install the sublime package “Babel”. Hit CTRL + SHIFT + P do “Package Control: Install Package” and install “Babel”. Now open any .jsx file and in Sublime Text do:

View -> Syntax -> Open all with current extension as ... -> Babel -> Javascript (Babel)

Hi, I'm Christoph Michel 👋

I'm a , , and .

Currently, I mostly work in software security and do on an independent contractor basis.

I strive for efficiency and therefore track many aspects of my life.