vue 如何判断两个数组相同_Vue.js实现将一个数组内的相同数据进行合并

Vue.js实现将一个数组内的相同数据进行合并

发布于 2020-3-6|

复制链接

分享一篇关于vue实现将一个数组内的相同数据进行合并,具有很好的参考价值,希望对大家有所帮助。一起跟随小妖过来看看吧

获取服务器传来的数组数据进行,找出其中价格相同的进行数量相加,合并该段数据:

```javascript

/** 先将传来的订单列表进行四舍五入,再将价格相同的订单进行合并

* @param {Object} orderList :要进行操作的订单

*/

async mergeOrder(orderList) {

console.log(orderList);

let contrast_1 = JSON.parse(JSON.stringify(orderList));

for(let x in contrast_1){

contrast_1[x].trade_price = this.toDecimal(contrast_1[x].trade_price,this.digit_num); //进行四舍五入

}

let contrast_2 = JSON.parse(JSON.stringify(contrast_1)); //再复制一个用来做对比

let containers = []; //存放已经合并后的数据

/* 循环找出相同的值 */

console.log(contrast_1);

for(let i in contrast_1){

console.log(contrast_1[i]);

let container_list = {

trade_num: contrast_1[i].trade_num,

trade_order_id: contrast_1[i].trade_order_id,

trade_price: contrast_1[i].trade_price,

trade_type: contrast_1[i].trade_type

}

for(let m in contrast_2){

if(!contrast_2[m]){

if(m == i){

container_list = null;

break; //如果该值为空值就跳过

}

continue;

}

if(contrast_1[i].trade_price == contrast_2[m].trade_price){

if(m == i){

contrast_2[m] = null;

continue;

}

/* 如果遇到没有合并的相同价格就进行累加 */

container_list = {

trade_num: parseInt(container_list.trade_num) + parseInt(contrast_2[m].trade_num),

trade_order_id: container_list.trade_order_id + '--' + contrast_2[m].trade_order_id,

trade_price: container_list.trade_price,

trade_type: container_list.trade_type

}

contrast_2[m] = null; //销毁该次循环的值,防止多次循环到该值

}

}

console.log(container_list);

if(!container_list){

//如果为空值就直接进行下次循环

continue;

}

/* 将该次循环得到的数据放入容器内 */

containers.push(container_list);

console.log(containers);

}

console.log(containers);

return containers;

}

```

```javascript

/**

* @param {number} x: 要进行操作的数字

* @param {number} digit: 要达到的精度,比如小数点后8位,不足补0

*/

toDecimal(x, digit) {

let f = parseFloat(x);

let index = Math.pow(10, digit);

if (isNaN(f)) {

return false;

}

f = Math.round(x * index) / index; //四舍五入

let s = f.toString();

let rs = s.indexOf('.');

if (rs 0) {

s += '.';

}

}

if (digit > 0) {

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值