JavaScript更新数组值(如果存在),否则将新数组推送到对象

时间:2019-04-25 21:42:08

标签: javascript jquery multidimensional-array array-push

我正在尝试更新数组中的值(如果没有找到的话),然后向其添加新的数组。

这是我一直在尝试的一些代码:

var cartItems = {};
var items = []
cartItems.items = items;
$('.proAdd').click(function(){
var name = $(this).attr("data-name");
var price = parseFloat($(this).attr("data-price"));
var quantity = parseInt($(this).attr("data-quantity"));

var item = {"name": name,"price": price,"quantity": quantity}

items.forEach(function(item) {
if (item.name === name) {
item.quantity = 2
return; 
}else{
cartItems.items.push(item);
}
});

在此版本中,注意被推送。如果我取出else分支,则它会更新它,但也会推送它。我创建了一个fiddle for this

也尝试过此方法,但它说x.quantity未定义:

var index = items.findIndex(x => x.name==name)
if (index != -1){
x.quantity = 2
}
else {
cartItems.items.push(item);
}

1 个答案:

答案 0 :(得分:0)

因为index存储项目的索引,而x是一个临时值,在该行之后不可用。请改用find,并确保每次都看相同的items

var item = cartItems.items.find(x => x.name == name);
if (item) {
  item.quantity = 2;
} else {
  cartItems.items.push(item);
}