| 12345678910111213141516171819202122232425262728293031323334 | var arrayFilter = require('./_arrayFilter'),    baseRest = require('./_baseRest'),    baseXor = require('./_baseXor'),    isArrayLikeObject = require('./isArrayLikeObject'),    last = require('./last');/** * This method is like `_.xor` except that it accepts `comparator` which is * invoked to compare elements of `arrays`. The order of result values is * determined by the order they occur in the arrays. The comparator is invoked * with two arguments: (arrVal, othVal). * * @static * @memberOf _ * @since 4.0.0 * @category Array * @param {...Array} [arrays] The arrays to inspect. * @param {Function} [comparator] The comparator invoked per element. * @returns {Array} Returns the new array of filtered values. * @example * * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; * * _.xorWith(objects, others, _.isEqual); * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }] */var xorWith = baseRest(function(arrays) {  var comparator = last(arrays);  comparator = typeof comparator == 'function' ? comparator : undefined;  return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator);});module.exports = xorWith;
 |