The Wayback Machine - https://web.archive.org/web/20170626184621/https://github.com/lodash/lodash/blob/master/unionBy.js
Skip to content
Permalink
6cb3460 Feb 6, 2017
@jdalton @bertyhell
33 lines (30 sloc) 1.06 KB
import baseFlatten from './.internal/baseFlatten.js'
import baseUniq from './.internal/baseUniq.js'
import isArrayLikeObject from './isArrayLikeObject.js'
import last from './last.js'
/**
* This method is like `union` except that it accepts `iteratee` which is
* invoked for each element of each `arrays` to generate the criterion by
* which uniqueness is computed. Result values are chosen from the first
* array in which the value occurs. The iteratee is invoked with one argument:
* (value).
*
* @since 4.0.0
* @category Array
* @param {...Array} [arrays] The arrays to inspect.
* @param {Function} iteratee The iteratee invoked per element.
* @returns {Array} Returns the new array of combined values.
* @see difference, union, unionWith, without, xor, xorBy
* @example
*
* unionBy([2.1], [1.2, 2.3], Math.floor)
* // => [2.1, 1.2]
*/
function unionBy(...arrays) {
let iteratee = last(arrays)
if (isArrayLikeObject(iteratee)) {
iteratee = undefined
}
return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), iteratee)
}
export default unionBy
You can't perform that action at this time.
You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session.
Morty Proxy This is a proxified and sanitized view of the page, visit original site.