mirror of
https://github.com/whoisclebs/lodash.git
synced 2026-01-31 15:27:50 +00:00
54 lines
1.5 KiB
JavaScript
54 lines
1.5 KiB
JavaScript
import apply from './.internal/apply.js'
|
|
import arrayPush from './.internal/arrayPush.js'
|
|
import castSlice from './.internal/castSlice.js'
|
|
import toInteger from './toInteger.js'
|
|
|
|
/* Built-in method references for those with the same name as other `lodash` methods. */
|
|
const nativeMax = Math.max
|
|
|
|
/**
|
|
* Creates a function that invokes `func` with the `this` binding of the
|
|
* create function and an array of arguments much like
|
|
* [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).
|
|
*
|
|
* **Note:** This method is based on the
|
|
* [spread operator](https://mdn.io/spread_operator).
|
|
*
|
|
* @since 3.2.0
|
|
* @category Function
|
|
* @param {Function} func The function to spread arguments over.
|
|
* @param {number} [start=0] The start position of the spread.
|
|
* @returns {Function} Returns the new function.
|
|
* @example
|
|
*
|
|
* const say = spread((who, what) => `${ who } says ${ what }`)
|
|
*
|
|
* say(['fred', 'hello'])
|
|
* // => 'fred says hello'
|
|
*
|
|
* const numbers = Promise.all([
|
|
* Promise.resolve(40),
|
|
* Promise.resolve(36)
|
|
* ])
|
|
*
|
|
* numbers.then(spread((x, y) => x + y))
|
|
* // => a Promise of 76
|
|
*/
|
|
function spread(func, start) {
|
|
if (typeof func != 'function') {
|
|
throw new TypeError('Expected a function')
|
|
}
|
|
start = start == null ? 0 : nativeMax(toInteger(start), 0)
|
|
return (...args) => {
|
|
const array = args[start]
|
|
const otherArgs = castSlice(args, 0, start)
|
|
|
|
if (array) {
|
|
arrayPush(otherArgs, array)
|
|
}
|
|
return apply(func, this, otherArgs)
|
|
}
|
|
}
|
|
|
|
export default spread
|