常用的lodash方法

文章目录

  • 前言
  • 一、常用的lodash方法总结
  • 二、使用步骤
    • 1._.chunk(array, [size=1]) “数组切割”
    • 2_.cloneDeep(value) “深拷贝”
    • 3_.compact(array) “过滤假值”
    • 4_.remove(array, [predicate=_.identity]) “移除数组对象中指定元素”
    • 5_.unionWith([arrays], [comparator]) “数组对象合并去重”
    • 6_.map(collection, [iteratee=_.identity]) “过滤”
    • 7_.uniqBy(array, [iteratee=_.identity]) “数组对象去重”
    • 8_.pullAll(array, values) “移除数组指定元素”
    • 8_.pullAllWith(array, values, [comparator]) “移除数组对象指定元素”
  • 总结


前言

lodash常用方法


提示:以下是本篇文章正文内容,下面案例可供参考

一、常用的lodash方法总结

二、使用步骤

1._.chunk(array, [size=1]) “数组切割”

将数组(array)拆分成多个 size 长度的区块,并将这些区块组成一个新数组。 如果array 无法被分割成全部等长的区块,那么最后剩余的元素将组成一个区块。

// => [['a', 'b'], ['c', 'd']]
 
_.chunk(['a', 'b', 'c', 'd'], 3);
// => [['a', 'b', 'c'], ['d']]

2_.cloneDeep(value) “深拷贝”

这个方法类似_.clone,除了它会递归拷贝 value。(注:也叫深拷贝)。

var objects = [{ 'a': 1 }, { 'b': 2 }];
 
var deep = _.cloneDeep(objects);
console.log(deep[0] === objects[0]);
// => false

3_.compact(array) “过滤假值”

创建一个新数组,包含原数组中所有的非假值元素。例如false, null,0, “”, undefined, 和 NaN 都是被认为是“假值”。

_.compact([0, 1, false, 2, '', 3]);
// => [1, 2, 3]

4_.remove(array, [predicate=_.identity]) “移除数组对象中指定元素”

移除数组中predicate(断言)返回为真值的所有元素,并返回移除元素组成的数组。predicate(断言) 会传入3个参数: (value, index, array)。

Note: 和_.filter不同, 这个方法会改变数组 array。使用_.pull来根据提供的value值从数组中移除元素。

var array = [1, 2, 3, 4];
var evens = _.remove(array, function(n) {
  return n % 2 == 0;
});
 
console.log(array);
// => [1, 3]
 
console.log(evens);
// => [2, 4]

5_.unionWith([arrays], [comparator]) “数组对象合并去重”

这个方法类似_.union, 除了它接受一个 comparator 调用比较arrays数组的每一个元素。 comparator 调用时会传入2个参数: (arrVal, othVal)。

var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];
var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];
 
_.unionWith(objects, others, _.isEqual);
// => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]

6_.map(collection, [iteratee=_.identity]) “过滤”

创建一个数组, value(值) 是 iteratee(迭代函数)遍历 collection(集合)中的每个元素后返回的结果。 iteratee(迭代函数)调用3个参数:
(value, index|key, collection).

function square(n) {
  return n * n;
}
 
_.map([4, 8], square);
// => [16, 64]
 
_.map({ 'a': 4, 'b': 8 }, square);
// => [16, 64] (iteration order is not guaranteed)
 
var users = [
  { 'user': 'barney' },
  { 'user': 'fred' }
];
 
// The `_.property` iteratee shorthand.
_.map(users, 'user');
// => ['barney', 'fred']

7_.uniqBy(array, [iteratee=_.identity]) “数组对象去重”

这个方法类似_.uniq ,除了它接受一个 iteratee (迭代函数),调用每一个数组(array)的每个元素以产生唯一性计算的标准。iteratee 调用时会传入一个参数:(value)。

_.uniqBy([2.1, 1.2, 2.3], Math.floor);
// => [2.1, 1.2]
 
// The `_.property` iteratee shorthand.
_.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');
// => [{ 'x': 1 }, { 'x': 2 }]

8_.pullAll(array, values) “移除数组指定元素”

这个方法类似_.pull,区别是这个方法接收一个要移除值的数组。

Note: 不同于_.difference, 这个方法会改变数组 array。

var array = [1, 2, 3, 1, 2, 3];
 
_.pullAll(array, [2, 3]);
console.log(array);
// => [1, 1]

8_.pullAllWith(array, values, [comparator]) “移除数组对象指定元素”

这个方法类似_.pull,区别是这个方法接收一个要移除值的数组。
Note: 不同于_.difference, 这个方法会改变数组 array。

var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }];
 
_.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual);
console.log(array);
// => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }]


总结

后续陆续更新:
以上就是今天要讲的内容,本文仅仅简单介绍了常用的lodash的使用,而lodash提供了大量能使我们快速便捷地处理数据的函数和方法。

你可能感兴趣的:(javascript,前端,开发语言)