mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-02-06 09:47:48 +00:00
Move baseUpdate and update definitions.
This commit is contained in:
86
lodash.js
86
lodash.js
@@ -3451,19 +3451,6 @@
|
|||||||
return object;
|
return object;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The base implementation of `_.update`.
|
|
||||||
*
|
|
||||||
* @private
|
|
||||||
* @param {Object} object The object to query.
|
|
||||||
* @param {Array|string} path The path of the property to update.
|
|
||||||
* @param {Function} updater The function to produce the updated value.
|
|
||||||
* @returns {Object} Returns `object`.
|
|
||||||
*/
|
|
||||||
function baseUpdate(object, path, updater) {
|
|
||||||
return baseSet(object, path, updater(baseGet(object, path)));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The base implementation of `setData` without support for hot loop detection.
|
* The base implementation of `setData` without support for hot loop detection.
|
||||||
*
|
*
|
||||||
@@ -3720,6 +3707,19 @@
|
|||||||
return (object != null && has(object, key)) ? delete object[key] : true;
|
return (object != null && has(object, key)) ? delete object[key] : true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The base implementation of `_.update`.
|
||||||
|
*
|
||||||
|
* @private
|
||||||
|
* @param {Object} object The object to query.
|
||||||
|
* @param {Array|string} path The path of the property to update.
|
||||||
|
* @param {Function} updater The function to produce the updated value.
|
||||||
|
* @returns {Object} Returns `object`.
|
||||||
|
*/
|
||||||
|
function baseUpdate(object, path, updater) {
|
||||||
|
return baseSet(object, path, updater(baseGet(object, path)));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The base implementation of methods like `_.dropWhile` and `_.takeWhile`
|
* The base implementation of methods like `_.dropWhile` and `_.takeWhile`
|
||||||
* without support for iteratee shorthands.
|
* without support for iteratee shorthands.
|
||||||
@@ -11912,37 +11912,6 @@
|
|||||||
return object == null ? object : baseSet(object, path, value);
|
return object == null ? object : baseSet(object, path, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Updates the value at `path` of `object` with given `func`. If a portion
|
|
||||||
* of `path` doesn't exist it's created. Arrays are created for missing index
|
|
||||||
* properties while objects are created for all other missing properties.
|
|
||||||
* The `func` is invoked with `value` at `path` of `object`: (value).
|
|
||||||
*
|
|
||||||
* @static
|
|
||||||
* @memberOf _
|
|
||||||
* @category Object
|
|
||||||
* @param {Object} object The object to modify.
|
|
||||||
* @param {Array|string} path The path of the property to set.
|
|
||||||
* @param {Function} updater The function to produce the updated value.
|
|
||||||
* @returns {Object} Returns the updated `object`.
|
|
||||||
* @example
|
|
||||||
*
|
|
||||||
* var object = { 'a': [{ 'b': { 'c': 3, 'd': '11' } }] };
|
|
||||||
*
|
|
||||||
* _.update(object, 'a[0].b.c', function(n) { return n + 10; });
|
|
||||||
* console.log(object.a[0].b.c);
|
|
||||||
* // => 13
|
|
||||||
*
|
|
||||||
* _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });
|
|
||||||
* console.log(object.x[0].y.z);
|
|
||||||
* // => 0
|
|
||||||
*/
|
|
||||||
function update(object, path, updater) {
|
|
||||||
return object == null
|
|
||||||
? object
|
|
||||||
: baseUpdate(object, path, baseCastFunction(updater));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method is like `_.set` except that it accepts `customizer` which is
|
* This method is like `_.set` except that it accepts `customizer` which is
|
||||||
* invoked to produce the objects of `path`. If `customizer` returns `undefined`
|
* invoked to produce the objects of `path`. If `customizer` returns `undefined`
|
||||||
@@ -12099,6 +12068,35 @@
|
|||||||
return object == null ? true : baseUnset(object, path);
|
return object == null ? true : baseUnset(object, path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates the value at `path` of `object` with given `func`. If a portion
|
||||||
|
* of `path` doesn't exist it's created. Arrays are created for missing index
|
||||||
|
* properties while objects are created for all other missing properties.
|
||||||
|
* The `func` is invoked with `value` at `path` of `object`: (value).
|
||||||
|
*
|
||||||
|
* @static
|
||||||
|
* @memberOf _
|
||||||
|
* @category Object
|
||||||
|
* @param {Object} object The object to modify.
|
||||||
|
* @param {Array|string} path The path of the property to set.
|
||||||
|
* @param {Function} updater The function to produce the updated value.
|
||||||
|
* @returns {Object} Returns the updated `object`.
|
||||||
|
* @example
|
||||||
|
*
|
||||||
|
* var object = { 'a': [{ 'b': { 'c': 3, 'd': '11' } }] };
|
||||||
|
*
|
||||||
|
* _.update(object, 'a[0].b.c', function(n) { return n + 10; });
|
||||||
|
* console.log(object.a[0].b.c);
|
||||||
|
* // => 13
|
||||||
|
*
|
||||||
|
* _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });
|
||||||
|
* console.log(object.x[0].y.z);
|
||||||
|
* // => 0
|
||||||
|
*/
|
||||||
|
function update(object, path, updater) {
|
||||||
|
return object == null ? object : baseUpdate(object, path, baseCastFunction(updater));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an array of the own enumerable property values of `object`.
|
* Creates an array of the own enumerable property values of `object`.
|
||||||
*
|
*
|
||||||
|
|||||||
Reference in New Issue
Block a user