这是一个 lodash
加强版的工具库,
lodash
只提供了最基础的一些工具方法,当我们在业务上使用时,往往需要对其进行再次封装,比较麻烦。
所以,提供了一个在 业务场景中 更加 通用的工具库。
希望对你有所帮助!
npm install lodash-super
或 yarn add lodash-super
将 对象数组(由对象组成的数组) 转换成 对象
const obj = _S.array2obj([{key:'label1',value:1},{key:'label2',value:2}])
// => {label1:1,label2:2}
const obj1 = _S.array2obj([{name:'label1',id:1},{name:'label2',id:2}],'name','id')
// => {label1:1,label2:2}
将 对象 转换成 对象数组(由对象组成的数组)
(Array): 返回生成的新数组。
const obj = _S.obj2array({label1:1,label2:2})
// => [{key:'label1',value:1},{key:'label2',value:2}]
const obj1 = _S.obj2array({label1:1,label2:2} ,'name','id')
// => [{name:'label1',id:1},{name:'label2',id:2}]
取出 对象数组 中满足的条件的那一项项 的指定的值
const obj = _S.filterBy([{id:1,name:'1'},{id:2,name:'2'}], 'id', 1, 'name')
// => '1'
对数值 进行进位 转换
const field = _S.formatUnit(1048576)
// => {size:1.00,unit'M'}
const field2 = _S.formatUnit(1048576,'KB')
// => {size:1.00,unit'G'}
const field3 = _S.formatUnit(1000000,'KB',2,1000)
// => 按1000进位 {size:1.00,unit'G'}
对数值进行显示简化
const field = _S.formatUnit(1048576)
// => {size:1,unit:'M'}
const field2 = _S.formatUnit(1048576,'KB')
// => {size:1,unit:'G'}
const field3 = _S.formatUnit(1000000,'KB',2,1000)
// => 按1000进位 {size:1,unit'G'}
对数值 进行进位 转换
const field = _S.formatUnitChange(2000)
// => 1.953
const field2 = _S.formatUnitChange(2,'KB','B')
// => 2048
对时间进行显示简化
const field = _S.formatUnitT(1000)
// => {size:1,unit:'s'}
const field2 = _S.formatUnitT(60,'s')
// => {size:1,unit:'m'}
对时间 进行进位 转换
const field = _S.formatUnitChangeT(2000)
// => 2
const field2 = _S.formatUnitChangeT(2,'m','s')
// => 120
随机生成指定位数和范围的字符串
const field = _S.randomStr()
// => efcww
判断 对象数组内是否有相同key 的value 值
const flag = repeatKey([{ name: 1,} { name: 1 }])
// => true
const flag = repeatKey([{ name1: { name: 1 } }, { name1: { name: 1 } }, { name1: '1' }], ['name1', 'name'])
// => true
过滤出 对象数组内,满足 comparator
条件并为 true
的对象,同时也对对象内的 children
有效。
如果
children
满足条件,则对应的父级也会被保留comparator
也接收一个字符串,对象拥有这个属性会被保留
const field1 = filterField([{ name: 1,children:[{name:1}]} { name: 2 }],(obj) => obj.name ===1)
// => [{name:1,children:[{name:1}}]
const field2 = filterField([{ name: 2 }, { name:3,children:[{ name: 1 }] }, (obj) => obj.name ===1])
// => [{name:3,children:[{name:1}}]
const field1 = filterField([{ name: 1} { name1: 2 }],'name')
// => [{name:1}]