A utility library delivering consistency, customization, performance, & extras.
We’ve got API docs, benchmarks, and unit tests.
Create your own benchmarks at jsPerf, or search for existing ones.
For a list of upcoming features, check out our roadmap.
For more information check out these screencasts over Lo-Dash:
fromIndex argumentObject constructorthis bindingcallback and thisArg argumentsLo-Dash has been tested in at least Chrome 5~23, Firefox 1~16, IE 6-10, Opera 9.25-12, Safari 3-6, Node.js 0.4.8-0.8.14, Narwhal 0.3.2, RingoJS 0.8, and Rhino 1.7RC5.
In browsers:
<script src="lodash.js"></script>
Using npm:
npm install lodash
npm install -g lodash
npm link lodash
In Node.js and RingoJS v0.8.0+:
var _ = require('lodash');
Note: If Lo-Dash is installed globally, run npm link lodash in your project’s root directory before requiring it.
In RingoJS v0.7.0-:
var _ = require('lodash')._;
In Rhino:
load('lodash.js');
In an AMD loader like RequireJS:
require({
  'paths': {
    'underscore': 'path/to/lodash'
  }
},
['underscore'], function(_) {
  console.log(_.VERSION);
});
length property [#799, test]_.isEmpty should support jQuery/MooTools DOM query collections [#690, test]_.isObject should avoid V8 bug #2291 [#605, test]_.keys should work with arguments objects cross-browser [#396, test]_.range should coerce arguments to numbers [#634, #683, test]fromIndex argument to _.containsmoduleId build option_.max and _.min_.template_.every, _.find, _.some, and _.uniqThe full changelog is available here.
Lo-Dash is part of the BestieJS “Best in Class” module collection. This means we promote solid browser/environment support, ES5 precedents, unit testing, and plenty of documentation.
| John-David Dalton | 
| Blaine Bublitz | Kit Cambridge | Mathias Bynens |