Correct way to import lodash

JavascriptLodashBabeljs

Javascript Problem Overview


I had a pull request feedback below, just wondering which way is the correct way to import lodash?

> You'd better do import has from 'lodash/has'.. For the earlier version > of lodash (v3) which by itself is pretty heavy, we should only import > a specidic module/function rather than importing the whole lodash > library. Not sure about the newer version (v4).

import has from 'lodash/has';

vs

import { has } from 'lodash';

Thanks

Javascript Solutions


Solution 1 - Javascript

import has from 'lodash/has'; is better because lodash holds all it's functions in a single file, so rather than import the whole 'lodash' library at 100k, it's better to just import lodash's has function which is maybe 2k.

Solution 2 - Javascript

If you are using webpack 4, the following code is tree shakable.

import { has } from 'lodash-es';

The points to note;

  1. CommonJS modules are not tree shakable so you should definitely use lodash-es, which is the Lodash library exported as ES Modules, rather than lodash (CommonJS).

  2. lodash-es's package.json contains "sideEffects": false, which notifies webpack 4 that all the files inside the package are side effect free (see https://webpack.js.org/guides/tree-shaking/#mark-the-file-as-side-effect-free).

  3. This information is crucial for tree shaking since module bundlers do not tree shake files which possibly contain side effects even if their exported members are not used in anywhere.

Edit

As of version 1.9.0, Parcel also supports "sideEffects": false, threrefore import { has } from 'lodash-es'; is also tree shakable with Parcel. It also supports tree shaking CommonJS modules, though it is likely tree shaking of ES Modules is more efficient than CommonJS according to my experiment.

Solution 3 - Javascript

>Import specific methods inside of curly brackets > > import { map, tail, times, uniq } from 'lodash'; > >Pros: > > - Only one import line(for a decent amount of functions) > - More readable usage: map() instead of _.map() later in the javascript code. > >Cons: > > - Every time we want to use a new function or stop using another - it needs to be maintained and managed

Copied from:The Correct Way to Import Lodash Libraries - A Benchmark article written by Alexander Chertkov.

Solution 4 - Javascript

You can import them as

import {concat, filter, orderBy} from 'lodash';

or as

import concat from 'lodash/concat';
import orderBy from 'lodash/orderBy';
import filter from 'lodash/filter';

the second one is much optimized than the first because it only loads the needed modules

then use like this

pendingArray: concat(
                    orderBy(
                        filter(payload, obj => obj.flag),
                        ['flag'],
                        ['desc'],
                    ),
                    filter(payload, obj => !obj.flag),

Solution 5 - Javascript

If you are using babel, you should check out babel-plugin-lodash, it will cherry-pick the parts of lodash you are using for you, less hassle and a smaller bundle.

It has a few 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

Solution 6 - Javascript

I just put them in their own file and export it for node and webpack:

// lodash-cherries.js
module.exports = {
  defaults: require('lodash/defaults'),
  isNil: require('lodash/isNil'),
  isObject: require('lodash/isObject'),
  isArray: require('lodash/isArray'),
  isFunction: require('lodash/isFunction'),
  isInteger: require('lodash/isInteger'),
  isBoolean: require('lodash/isBoolean'),
  keys: require('lodash/keys'),
  set: require('lodash/set'),
  get: require('lodash/get'),
}

Solution 7 - Javascript

I think this answer can be used in any project easily and brings the best result with less effort.

For Typescript users, use as following :

// lodash.utils.ts
export { default as get } from 'lodash/get';
export { default as isEmpty } from 'lodash/isEmpty';
export { default as isNil } from 'lodash/isNil';
...

And can be used the same way as importing lodash :

//some-code.ts
import { get } from './path/to/lodash.utils'

export static function getSomething(thing: any): any {
    return get(thing, 'someSubField', 'someDefaultValue')
}

Or if you prefer to keep the _ to avoid conflicts (ex. map from rxjs vs lodash)

//some-other-code.ts
import * as _ from './path/to/lodash.utils'

export static function getSomething(thing: any): any {
    return _.get(thing, 'someSubField', 'someDefaultValue')
}

UPDATE : Seems like the right way to export is :

export * as get from 'lodash/get';
export * as isEmpty from 'lodash/isEmpty';
export * as isNil from 'lodash/isNil';
...

But there is a weird collision with @types/lodash, I've removed this type package because I would get this error :

> Module '"/../project/node_modules/@types/lodash/cloneDeep"' uses > 'export =' and cannot be used with 'export *'.ts(2498)

UPDATE :

After some digging, I've turned tsconfig.json feature esModuleInterop to true, and it allows me to do the following :

import get from 'lodash/get';
import isEmpty from 'lodash/isEmpty';
import isNil from 'lodash/isNil';
...

export { get, isEmpty, isNil, ... };

Note that this affects all your imports in your projects that has been defined as import * as lib from 'lib'. Follow the documentation to be sure it's suitable for you.

Solution 8 - Javascript

For those who want to keep using _ , then just import them like this:

import groupBy from 'lodash/groupBy';
import filter from 'lodash/filter';
import get from 'lodash/get';

window._ = {groupBy, filter, get};

Solution 9 - Javascript

import { cloneDeep, groupBy } from 'lodash';

I think this is simpler when you don't need to convert array to lodash object by using _.

const groupData = groupBy(expandedData, (x) => x.room.name);

Solution 10 - Javascript

I think the more cleaner way of importing lodash is just like this:-

import _ from 'lodash'

then you can use what ever you want just by using this underscore just like this:-

_.has()

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionBillView Question on Stackoverflow
Solution 1 - JavascriptBillView Answer on Stackoverflow
Solution 2 - JavascriptkimamulaView Answer on Stackoverflow
Solution 3 - JavascriptNikhilView Answer on Stackoverflow
Solution 4 - JavascriptCharith JayasankaView Answer on Stackoverflow
Solution 5 - JavascriptOrlandoView Answer on Stackoverflow
Solution 6 - JavascriptAronandaView Answer on Stackoverflow
Solution 7 - JavascriptSamuel CardinalView Answer on Stackoverflow
Solution 8 - JavascriptMadian MalfiView Answer on Stackoverflow
Solution 9 - JavascriptNam DoView Answer on Stackoverflow
Solution 10 - JavascriptRtesaView Answer on Stackoverflow