mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-02-07 01:57:50 +00:00
Ensure _.min and _.max can be used as the callback of _.map. [closes #379]
This commit is contained in:
31
lodash.js
31
lodash.js
@@ -2918,6 +2918,7 @@
|
||||
if (!isObject(object)) {
|
||||
return object;
|
||||
}
|
||||
|
||||
// allows working with `_.reduce` and `_.reduceRight` without using
|
||||
// their `index` and `collection` arguments
|
||||
if (typeof args[2] != 'number') {
|
||||
@@ -3797,7 +3798,12 @@
|
||||
var computed = -Infinity,
|
||||
result = computed;
|
||||
|
||||
if (!callback && isArray(collection)) {
|
||||
// allows working with functions like `_.map` without using
|
||||
// their `index` argument as a callback
|
||||
if (typeof callback != 'function' && thisArg && thisArg[callback] === collection) {
|
||||
callback = null;
|
||||
}
|
||||
if (callback == null && isArray(collection)) {
|
||||
var index = -1,
|
||||
length = collection.length;
|
||||
|
||||
@@ -3808,7 +3814,7 @@
|
||||
}
|
||||
}
|
||||
} else {
|
||||
callback = (!callback && isString(collection))
|
||||
callback = (callback == null && isString(collection))
|
||||
? charAtCallback
|
||||
: lodash.createCallback(callback, thisArg, 3);
|
||||
|
||||
@@ -3867,7 +3873,12 @@
|
||||
var computed = Infinity,
|
||||
result = computed;
|
||||
|
||||
if (!callback && isArray(collection)) {
|
||||
// allows working with functions like `_.map` without using
|
||||
// their `index` argument as a callback
|
||||
if (typeof callback != 'function' && thisArg && thisArg[callback] === collection) {
|
||||
callback = null;
|
||||
}
|
||||
if (callback == null && isArray(collection)) {
|
||||
var index = -1,
|
||||
length = collection.length;
|
||||
|
||||
@@ -3878,7 +3889,7 @@
|
||||
}
|
||||
}
|
||||
} else {
|
||||
callback = (!callback && isString(collection))
|
||||
callback = (callback == null && isString(collection))
|
||||
? charAtCallback
|
||||
: lodash.createCallback(callback, thisArg, 3);
|
||||
|
||||
@@ -4052,8 +4063,8 @@
|
||||
* @category Collections
|
||||
* @param {Array|Object|string} collection The collection to sample.
|
||||
* @param {number} [n] The number of elements to sample.
|
||||
* @param- {Object} [guard] Allows working with functions, like `_.map`,
|
||||
* without using their `key` and `object` arguments as sources.
|
||||
* @param- {Object} [guard] Allows working with functions like `_.map`
|
||||
* without using their `index` arguments as `n`.
|
||||
* @returns {Array} Returns the random sample(s) of `collection`.
|
||||
* @example
|
||||
*
|
||||
@@ -4595,7 +4606,7 @@
|
||||
// juggle arguments
|
||||
if (typeof isShallow != 'boolean' && isShallow != null) {
|
||||
thisArg = callback;
|
||||
callback = !(thisArg && thisArg[isShallow] === array) ? isShallow : null;
|
||||
callback = (typeof isShallow != 'function' && thisArg && thisArg[isShallow] === array) ? null : isShallow;
|
||||
isShallow = false;
|
||||
}
|
||||
if (callback != null) {
|
||||
@@ -4949,7 +4960,7 @@
|
||||
end = start;
|
||||
start = 0;
|
||||
}
|
||||
// use `Array(length)` so engines, like Chakra and V8, avoid slower modes
|
||||
// use `Array(length)` so engines like Chakra and V8 avoid slower modes
|
||||
// http://youtu.be/XAqIpGU8ZZk#t=17m25s
|
||||
var index = -1,
|
||||
length = nativeMax(0, ceil((end - start) / (step || 1))),
|
||||
@@ -5210,7 +5221,7 @@
|
||||
// juggle arguments
|
||||
if (typeof isSorted != 'boolean' && isSorted != null) {
|
||||
thisArg = callback;
|
||||
callback = !(thisArg && thisArg[isSorted] === array) ? isSorted : null;
|
||||
callback = (typeof isSorted != 'function' && thisArg && thisArg[isSorted] === array) ? null : isSorted;
|
||||
isSorted = false;
|
||||
}
|
||||
if (callback != null) {
|
||||
@@ -6865,7 +6876,7 @@
|
||||
// expose Lo-Dash
|
||||
var _ = runInContext();
|
||||
|
||||
// some AMD build optimizers, like r.js, check for condition patterns like the following:
|
||||
// some AMD build optimizers like r.js check for condition patterns like the following:
|
||||
if (typeof define == 'function' && typeof define.amd == 'object' && define.amd) {
|
||||
// Expose Lo-Dash to the global object even when an AMD loader is present in
|
||||
// case Lo-Dash was injected by a third-party script and not intended to be
|
||||
|
||||
Reference in New Issue
Block a user