博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
lodash常用函数 - Array、Collection
阅读量:5038 次
发布时间:2019-06-12

本文共 3040 字,大约阅读时间需要 10 分钟。

lodash常用函数 - Array、Collection

lodash版本 v3.10.1

1.Array、Collection

pull

移除数组中满足条件的元素

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

slice

从start位置到 end(但不包含end位置),截取 array数组

_.slice([1, 2, 3, 1],2,3)// => [3]

difference

排除第一个数组中不包含第二个数组的值

_.difference([1, 2, 3], [4, 2]);// => [1, 3]

findIndex

返回符合条件的元素的索引,没有找到返回-1

var users = [  { 'user': 'barney',  'active': false },  { 'user': 'fred',    'active': false },  { 'user': 'pebbles', 'active': true }];_.findIndex(users, 'active', false);// => 0

drop

将数组中的前n(默认是1)个元素去掉,返回剩余部分

_.drop([1, 2, 3], 2);// => [3]

xor

取出各数组中不等的元素

_.xor([1, 2], [4, 2]);// => [1, 4]

intersection

取出各数组中全等的元素

_.intersection([1, 2], [4, 2], [2, 1]);// => [2]

remove

删掉满足条件的元素

var array = [{name:'年龄',value:'34'},{name:'年龄',value:'20'},{name:'年龄',value:''}];_.remove(array, function(item) {    return item.value == '';})//[{name:'年龄',value:'34'},{name:'年龄',value:'20'}]

union

合并各数组的值,返回新数组

_.union([1, 2], [4, 2], [2, 1]);// => [1, 2, 4]

uniq

去除数组中的重复元素

_.uniq([2, 1, 2]);// => [2, 1]

==pluck==

取出json数组中某个属性的值,组成一个新数组返回

var users = [  { 'user': 'barney', 'age': 36 },  { 'user': 'fred',   'age': 40 }];_.pluck(users, 'user');// => ['barney', 'fred']

zipObject

由两个数组的元素配对组成一个新的对象

_.zipObject(['fred', 'barney'], [30, 40]);// => { 'fred': 30, 'barney': 40 }

filter

以新数组形式返回数组中满足条件的元素

_.filter([4, 5, 6], function(n) {  return n % 2 == 0;});// => [4, 6]var users = [  { 'user': 'barney', 'age': 36, 'active': true },  { 'user': 'fred',   'age': 40, 'active': false }];_.pluck(_.filter(users, 'active', false), 'user');// => ['fred']

find

返回数组中第一个满足条件的元素

var users = [  { 'user': 'barney',  'age': 36, 'active': true },  { 'user': 'fred',    'age': 40, 'active': false },  { 'user': 'pebbles', 'age': 1,  'active': true }];_.result(_.find(users, function(chr) {  return chr.age < 40;}), 'user');// => 'barney'// using the `_.matches` callback shorthand_.result(_.find(users, { 'age': 1, 'active': true }), 'user');// => 'pebbles'// using the `_.matchesProperty` callback shorthand_.result(_.find(users, 'active', false), 'user');// => 'fred'// using the `_.property` callback shorthand_.result(_.find(users, 'active'), 'user');// => 'barney'

includes

判断元素是否被包含在目标集合中

_.includes([1, 2, 3], 1);// => true_.includes([1, 2, 3], 1, 2);// => false_.includes({ 'user': 'fred', 'age': 40 }, 'fred');// => true_.includes('pebbles', 'eb');// => true

indexBy

从集合中获取某一个属性值生成新对象,属性值为新对象的键

var keyData = [  { 'dir': 'left', 'code': 97 },  { 'dir': 'right', 'code': 100 }];_.indexBy(keyData, 'dir');// => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }

sample

从集合中随机获取n个元素,n默认为1

_.sample([1, 2, 3, 4]);// => 2_.sample([1, 2, 3, 4], 2);// => [3, 1]

size

返回目标集合的长度

_.size([1, 2, 3]);// => 3_.size({ 'a': 1, 'b': 2 });// => 2_.size('pebbles');// => 7

sortBy

根据特定规则对集合进行排序

var users = [  { 'user': 'fred' },  { 'user': 'pebbles' },  { 'user': 'barney' }];_.pluck(_.sortBy(users, 'user'), 'user');// => ['barney', 'fred', 'pebbles']

转载于:https://www.cnblogs.com/chenchenghua/p/7682326.html

你可能感兴趣的文章
MATLAB GUI程序设计中使文本框接收多行输入的方法
查看>>
全文检索-Elasticsearch (四) elasticsearch.net 客户端
查看>>
Oracle DBMS_SESSION
查看>>
sublime复制当前行到下一行
查看>>
WPF 3D变换应用
查看>>
ArchLinux安装开源VMware Tools
查看>>
DB2 锁升级示例1
查看>>
16.RDD实战
查看>>
MainFrame知识小结(20120210)—dfsort/syncsort中的数据类型
查看>>
D - Flip tile
查看>>
Java连接RabbitMQ之创建连接
查看>>
开户vim编程之--cscope支持
查看>>
python数据类型图解
查看>>
C#微信登录-手机网站APP应用
查看>>
HTML5实践 -- iPhone Safari Viewport Scaling Bug
查看>>
一位数据挖掘成功人士 给 数据挖掘在读研究生 的建议
查看>>
Python3.6.0安装
查看>>
hdu1049
查看>>
H5项目常见问题及注意事项
查看>>
索尼(SONY) SVE1512S7C 把WIN8降成WIN7图文教程
查看>>