babel-plugin-lodash

3.3.4 • Public • Published

babel-plugin-lodash

A simple transform to cherry-pick Lodash modules so you don’t have to.

Combine with lodash-webpack-plugin for even smaller cherry-picked builds!

Install

$ npm i --save lodash
$ npm i --save-dev babel-plugin-lodash @babel/cli @babel/preset-env

Example

Transforms

import _ from 'lodash'
import { add } from 'lodash/fp'
 
const addOne = add(1)
_.map([1, 2, 3], addOne)

roughly to

import _add from 'lodash/fp/add'
import _map from 'lodash/map'
 
const addOne = _add(1)
_map([1, 2, 3], addOne)

Usage

.babelrc
{
  "plugins": ["lodash"],
  "presets": [["@babel/env", { "targets": { "node": 6 } }]]
}

Set plugin options using an array of [pluginName, optionsObject].

{
  "plugins": [["lodash", { "id": "lodash-compat", "cwd": "some/path" }]],
  "presets": [["@babel/env", { "targets": { "node": 6 } }]]
}

The options.id can be an array of ids.

{
  "plugins": [["lodash", { "id": ["async", "lodash-bound"] }]],
  "presets": [["@babel/env", { "targets": { "node": 6 } }]]
}
Babel CLI
$ babel --plugins lodash --presets @babel/es2015 script.js
Babel API
require('babel-core').transform('code', {
  'plugins': ['lodash'],
  'presets': [['@babel/env', { 'targets': { 'node': 6 } }]]
})
webpack.config.js
'module': {
  'loaders': [{
    'loader': 'babel-loader',
    'test': /\.js$/,
    'exclude': /node_modules/,
    'query': {
      'plugins': ['lodash'],
      'presets': [['@babel/env', { 'targets': { 'node': 6 } }]]
    }
  }]
}

FAQ

Can this plugin produce ES2015 imports rather than CommonJS imports?

This plugin produces ES2015 imports by default. The @babel/plugin-transform-modules-commonjs plugin, which is included in the @babel/preset-es2015 preset, transforms ES2015 import statements to CommonJS. Omit it from your preset to preserve ES2015 style imports.

Limitations

  • You must use ES2015 imports to load Lodash
  • Babel < 6 & Node.js < 4 aren’t supported
  • Chain sequences aren’t supported. See this blog post for alternatives.
  • Modularized method packages aren’t supported

Versions

Current Tags

VersionDownloads (Last 7 Days)Tag
3.3.4692,167latest

Version History

VersionDownloads (Last 7 Days)Published
3.3.4692,167
3.3.379
3.3.214,615
3.3.10
3.3.00
3.2.1113,365
3.2.1059
3.2.9484
3.2.81
3.2.70
3.2.60
3.2.50
3.2.47
3.2.31
3.2.20
3.2.144
3.2.01
3.1.50
3.1.41
3.1.30
3.1.21
3.1.10
3.1.01
3.0.00
2.3.01,657
2.2.30
2.2.20
2.2.10
2.2.00
0.3.00
2.1.00
2.0.12
2.0.00
1.1.00
1.0.20
1.0.10
1.0.00
0.2.010
0.1.50
0.1.41
0.1.31
0.1.20
0.1.10
0.1.00

Package Sidebar

Install

npm i babel-plugin-lodash

Weekly Downloads

722,497

Version

3.3.4

License

MIT

Unpacked Size

25.6 kB

Total Files

13

Last publish

Collaborators

  • jdalton
  • mathias