A Yeoman generator to author libraries in ES2015 (and beyond!) for Node and the browser.
- Author in ES2015 (even the unit tests)
- Export as ES5 & UMD
- Mocha-Chai-Sinon testing stack
- Unit tests that work in Node and in the browser
Install yo and this generator globally.
npm install -g yo generator-babel-boilerplate
Navigate to the directory you'd like to use for your project, then run yo babel-boilerplate.
Answer a few questions, and your project will be scaffolded.
Write your code in src. The entry file is what you named the project in kebab case (although the filename
can be changed).
Run npm run build to compile the source into a distributable format.
Put your unit tests in test/unit. The npm test command runs the tests using Node. If your library / tests
require the DOM API, see the test/setup/node.js file.
npm test- Lint the library and tests, then run the unit testsnpm run lint- Lint the source and unit testsnpm run watch- Continuously run the unit tests as you make changes to the source and test files themselvesnpm run test-browser- Build the library for use with the browser spec runner. Changes to the source will cause the runner to automatically refresh.npm run build- Lint then build the librarynpm run coverage- Generate a coverage report
The browser spec runner
can be opened in a browser to run your tests. For it to work, you must first run npm run test-browser. This
will set up a watch task that will automatically refresh the tests when your scripts, or the tests, change.
This library is set up to integrate with Code Climate. If you've never used Code Climate, then you might be wondering why it's useful. There are two reasons:
- It consumes code coverage reports, and provides a coverage badge for the README
- It provides interesting stats on your library, if you're into that kinda thing
Either of these items on the list can simply be ignored if you're uninterested in them. Or you can pull Code Climate out entirely from the boilerplate and not worry about it. To do that, update the relevant Gulp tasks and the Travis build.
If you'd like to set up Code Climate for your project, follow the steps here.
This boilerplate uses ESLint to lint your source. To
change the rules, edit the .eslintrc files in the root directory, respectively.
Given that your unit tests typically follow different rules from your library
code, it makes sense to lint them against a separate ESLint configuration. For
this reason, a separate, unit-test specific .eslintrc can be found in the
test directory.
Nearly all Babel features should be supported by this boilerplate.
If you're using certain experimental features, like class properties, async-await, types, or decorators, then you'll need to install babel-eslint to use as the parser for ESLint.
If you're still getting an error, follow these steps:
- Double check to make sure that you're not typoing the new syntax ;)
- Determine what task is failing (for instance, is it ESLint?)
- Check that project's issue tracker to see if it is a known issue
- If it isn't, then open an issue here
Because of the fact that dependencies of this boilerplate, such as ESLint, are maintained by a team separate from Babel, there may be a delay between when a new feature is added to Babel and when those other libraries add support for it.
This library is ideal for libraries that export a single file.
You can always use this boilerplate as inspiration, but it works best for smaller libraries. If you're building a full-scale webapp, you will likely need to make more changes to the build system. This is because the boilerplate only deals with JavaScript; common build tasks like CSS preprocessing, image minification, or HTML template building are intentionally omitted from this boilerplate.
There are so many different preferences and needs when it comes to building a webapp, it wouldn't make sense to pick any one configuration for this boilerplate.
In the broader scheme of things, there's been discussion in the JavaScript community over whether or not boilerplates are good, or if they are bad. There's no denying that you might could yourself lost is you pick this up without much experience with the tools used in this project. But it could also save you a lot of time if you're simply trying to get a build system set up and running.
Even if you don't intend to use this boilerplate, I believe that boilerplates are useful as an example and as a source of inspiration. I encourage you to look through the current state of the project, and through its history, to see different ways to use Babel with various tools!
As a rule of thumb, Babel works best in IE9 and above.
Quite a few. Check them out on the wiki.
There is not a maintained version for Node-only projects. As of Node v6, many of the most commonly used ES2015 features are now supported natively in Node. I strongly recommend that you weigh the pros and cons of adding a transpiling step to your server-side code!
A thorough analysis of this question can be found here.
This boilerplate is, to a degree, customizable. To make changes, find what you're looking to do below and follow the instructions.
The primary source file for the library is src/index.js. Only the files that this
file imports will be included in the final build. To change the name of this entry file:
- Rename the file
- Update the value of
entryFileNameinpackage.jsonunderbabelBoilerplateOptions
- Update
maininpackage.json
MyLibrary is the name of the variable exported from this boilerplate. You can change this by following
these steps:
- Ensure that the variable you're exporting exists in your scripts
- Update the value of
exportVarNameinpackage.jsonunderbabelBoilerplateOptions - Check that the unit tests have been updated to reference the new value
When prompted for the name of the library's main variable, leave the response empty.
Install the module and use it in your scripts like usual. Then, go into the Gulpfile and
add the externals to the
Webpack build options.
If you want to access the module itself in your unit test files, you will need to set up the test environment to support the module. To do this:
- Load the module in the test setup file.
- Add any imported variables to globals object in the test globals JSON.