Loads ES modules with CJS interop in Node according to https://github.com/nodejs/node-eps/blob/master/002-es6-modules.md.
Follows the NodeJS resolution algorithm, loading modules first as CJS and then falling back to ES on import or export syntax failures. This effectively provides the "export {}" assumption to load an ES module.
Built with the ES Module Loader polyfill 1.0 branch at https://github.com/ModuleLoader/es-module-loader.
npm install node-es-module-loader
Execute an ES module file:
node_modules/.bin/node-esml module.js
For example, where module.js
contains:
import fs from 'fs';
import {fn} from './local-es-module.js';
Note that only the default import form for CommonJS modules is supported.
Also supports dynamic loading via a loader
global (note that this will change in future when the dynamic loader spec is available);
export function lazyLoad(path) {
return loader.import(path);
}
Source maps also work in Node 6 with the node --inspect
flag via:
node --inspect node_modules/.bin/node-esml module.js
var NodeESModuleLoader = require('node-es-module-loader');
var loader = new NodeESModuleLoader(/* optional basePath */);
loader.import('x').then(function(m) {
// ...
});
- Does not currently support the "module" package.json proposal described in the second paragraph at https://github.com/nodejs/node-eps/blob/master/002-es6-modules.md#51-determining-if-source-is-an-es-module
- Does not allow any loading of ES modules from within CommonJS itself
- Does not implement global require filtering described in https://github.com/nodejs/node-eps/blob/master/002-es6-modules.md#521-removal-of-non-local-dependencies
- Does not provide CJS exports as named exports, skipping the algorithm defined in https://github.com/nodejs/node-eps/blob/master/002-es6-modules.md#311-dynamicmodulecreateo this may change, pending Node implementation intentions
Alternative Babel options can be set with a local .babelrc file.
MIT