素材牛VIP会员
JS 循环-陷入逻辑死区,求解答。
 阿***盗  分类:JavaScript  人气:1111  回帖:2  发布于6年前 收藏
dataHandler(opt){
      const miniCartListArr = [...this.miniCartListArr]
      let tempArr = []
      let data = {};
      if (miniCartListArr.length > 0) {
        miniCartListArr.forEach((item, idx) => {
          let $item = item;
          if ($item.skuId == opt.skuId) {
            data[opt.skuId] = true
            tempArr.push(opt)
          } else {
            tempArr.push($item)
          }
        })
      } else {
        opt.countNum = 1
        tempArr.push(opt)
      }
      this.setMiniCartListArr(tempArr)
    }

我是取到miniCartListArr ,如果他的个数大于0 就遍历miniCartListArr ,小于等于0 就直接把传递进来的opt推送到临时空数组里。回到遍历里面,我的目的是对比传递进来的对象ID 和遍历的当前ID 做比较,如果相同就push 传递进来的,不相同就push 当前遍历的对象,最后在把 新的tempArr(和miniCartListArr的区别就是多一个对象或者少一个对象,也有可能是改变其中一个对象) 存储起来。

但是现在,发现第一次是push 进去了,后面就没有PUSH进去,函数是出发了的,但是有问题。

写到这个地方遇到个小问题, 绕进去出不来了。求大佬思路。

传入参数格式
{
    skuId: 201108293321,
    price: 2.89,
    countNum: 1
}

每次传入的参数对象就是这样的。

讨论这个帖子(2)垃圾回帖将一律封号处理……

Lv4 码徒
飞***飞 产品经理 6年前#1

如果评论里的逻辑是对的。应该做有改无增的操作,而id不同的时候你并没有push。

// 简化版本
var miniCartListArr = []
var miniId = {}
function dataHandler (opt) {
    if (miniId[opt.skuId] !== undefined) {
        // 有改
        miniCartListArr[miniId[opt.skuId]] = opt
    } else {
        // 无增
        // 存 id:索引,方便下次有改
        miniId[opt.skuId] = miniCartListArr.length
        miniCartListArr.push(opt)
    }
}

arr2 = [...arr1]
这么写并不是个真的深拷贝。

var arr1 = [{name:1}]
arr2 = [...arr1]
arr2[0].name = 2
arr1[0].name // 1
arr1 === arr2 //false
arr1[0] === arr2[0] //true
Lv4 码徒
集***哈 页面重构设计 6年前#2
dataHandler(opt){
  const miniCartListArr = [...this.miniCartListArr]
  let tempArr = []
  let data = {};
  if (miniCartListArr.length > 0) {
    miniCartListArr.forEach((item, idx) => {
      let $item = item;
      if ($item.skuId == opt.skuId) { // 当opt在mincarListArr中时,使用opt替换
        data[opt.skuId] = true
        tempArr.push(opt)
      } else {
        tempArr.push($item)
      }
    })
    // 当opt不在mincarListArr中时,把opt添加在tmpArr的最后
    if (!data[opt.skuId]) {
      opt.countNum = 1
      tempArr.push(opt)
    }
  } else {
    opt.countNum = 1
    tempArr.push(opt)
  }
  this.setMiniCartListArr(tempArr)
}
 文明上网,理性发言!   😉 阿里云幸运券,戳我领取