ES6小技巧之代替lodash
前端  /  管理员 发布于 4年前   606
Javascript ES6标准实行后,Lodash或者Ramada中的一些功能我们就不需要了,可以使用ES6的语法来实现
获取Object中指定键值
我们现在可以使用解包的方法快速获取对象中指定键值的值
const obj = { a:1, b:2, c:3, d:4};// 获取obj中a与b的值const {a,b} = obj;// 也可以给他们取别名const {a:A, b:B} = obj;
这个小技巧非常的方便,也是最基础的使用方法
排除Object中不需要的键值
既然我们可以获取到想要的对象键值,那么也可以排除掉不想要的键值,使用方法就要用到ES6的rest新特性
const obj = { a:1, b:2, c:3, d:4}// 我们想要获取除了a之外的所有属性const {a, ...other} = obj
我们只要指定那些排除掉的属性,剩下的就是需要的属性,这样可以非常快速的排除不需要的属性
对象快速求和
有时候我们需要对一组对象数组中的某一个属性求总和,以前我们可以使用forEach或者for这样的循环遍历的方法来计算,现在我们可以使用reduce方法来快速实现
const objs = [{name:'lilei', score: 98},{name:'hanmeimei', score: 95},{name:'polo', score: 85},...]const scoreTotal = objs.reduce( (total, obj) => { return obj.score + total;}, 0 /*第二个参数是total的初始值*/)
使用reduce就能快速的实现对某一个属性的总和计算
map也能异步遍历
是不是觉得只有for能够进行异步操作不方便,其实map也能进行异步操作,不过需要结合Promise的新方法一起使用
const arr = [1,2,3,4,...]const queue = arr.map(async item => { return item + 1;})Promise.all(queue).then(newArr => console.log(newArr))
这样一来我们在map中也能使用异步操作了
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家的支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号