Vue计算属性中reduce方法实现遍历方式
作者:宏辉
这篇文章主要介绍了Vue计算属性中reduce方法实现遍历方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
vue计算属性reduce方法实现遍历
在前端页面中要实现一个商品购物车的遍历来计算出总价格,很多小伙伴都会想到用循环,可是这样编写的代码语句过于臃肿
下面我们来学习一下reduce方法实现遍历计算出商品总价格
未登录购物车:选中商品
在页面中,每个购物车商品左侧,都有一个复选框,用户可以选择部分商品进行下单,而不一定是全部:
我们定义一个selected变量,记录所有被选中的商品:
选中一个
我们给商品前面的复选框与selected绑定,并且指定其值为当前购物车商品:
初始化全选
我们在加载完成购物车查询后,初始化全选:
计算总价格(使用reduce方法)
然后编写一个计算属性,计算出选中商品总价格:
computed:{ //计算总价格 //数组的reduce()方法: /** * 参数一: 一个函数(使用箭头函数)代表运算逻辑 * 函数的两个参数 * c1: 用于存储累计的结果 * c2: 当前需要运算的元素 * 参数二: 默认值 */ totalPrice(){ return this.selected.reduce((c1,c2)=>c1+c2.price*c2.num,0); } },
在页面中展示总价格:
效果:
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。