Basic config
rollup.config.js
export default {
input: 'src/main.js',
output: {
file: 'bundle.js',
format: 'cjs'
}
}
Terminal
npm install -D rollup
Command | Description |
---|---|
rollup -c -o bundle.js |
bundle using config |
rollup main.js --o bundle.js --f cjs |
bundle |
rollup --watch |
bundle continuously |
You may need to use ./node_modules/.bin/rollup
as a command if you did not install rollup globally.
Multiple outputs
rollup.config.js
export default [
{
input: 'src/main.js',
output: {
file: __dirname + '/public/main.js',
format: 'cjs',
name: 'main'
}
},
{
input: 'src/vendor.js',
output: {
file: __dirname + 'public/vendor.js',
format: 'cjs',
name: 'vendor'
}
}
]
This creates main.js
and vendor.js
.
Using plugins
Plugins
Terminal
npm install -D @rollup/plugin-json
rollup.config.js
import json from '@rollup/plugin-json'
export default {
input: 'src/main.js',
output: {
file: 'bundle.js',
format: 'cjs'
},
plugins: [ json() ]
}
npm packages
Terminal
npm install -D @rollup/plugin-node-resolve
rollup.config.js
import resolve from '@rollup/plugin-node-resolve'
export default {
input: 'src/main.js',
output: {
file: 'bundle.js',
format: 'cjs'
},
plugins: [ resolve() ]
}
When you run a npm run build, no warning is emitted and contains the imported modules.
Peer dependencies
Terminal
npm install -D @rollup/plugin-node-resolve
rollup.config.js
import resolve from '@rollup/plugin-node-resolve'
export default {
input: 'src/main.js',
output: {
file: 'bundle.js',
format: 'cjs'
},
plugins: [resolve({
// pass custom options to the resolve plugin
customResolveOptions: {
moduleDirectory: 'node_modules'
}
})],
// indicate which modules should be treated as external
external: ['lodash']
}
Babel
Terminal
npm install -D @rollup/plugin-babel
rollup.config.js
import resolve from '@rollup/plugin-node-resolve'
import babel from '@rollup/plugin-babel'
export default {
input: 'src/main.js',
output: {
file: 'bundle.js',
format: 'cjs'
},
plugins: [
resolve(),
babel({
exclude: 'node_modules/**' // only transpile our source code
})
]
}
src/.babelrc
{
"presets": [
["latest", {
"es2015": {
"modules": false
}
}]
],
"plugins": ["external-helpers"]
}
0 Comments for this cheatsheet. Write yours!