繁体   English   中英

如何在 function 中使用引用嵌套 function 内部参数的条件语句在 javascript 中返回结果?

[英]How can use a conditional statement inside of a function that references the parameter inside of a nested function to return a result in javascript?

我有一个购物车,我需要能够向 function 添加有条件的折扣,该 function 当前获取商品的价格并将其乘以数量。 目前,function 就像没有折扣的魅力,但折扣需要能够判断是否有两个或多个具有相同“标签”的商品(例如“奶酪披萨”、“蘑菇披萨”、“夏威夷披萨”)然后从返回的总数中减去一个金额以使其工作。 我如何实现这一目标?

这个 function 获取用户购物车中所有商品项目的总价格金额

 get totalAmount() {
 let total = 0;
 this.cart.forEach(item => (total += this.getItemTotal(item)));

 ///// possible conditional statement here
 ////// something like  if (item.tags == "cheese"){
 /////// return total - 2;   }
 //////// ( currently just errors out to "**item not found**" even though I thought   
 ///// since the parameter "item" was in the function within the function it could recognize it)             


return total;
}

这个 function 在上面的 function 里面。 它用于获取单个项目的小计,包括它的选项

getItemTotal(item) {
 let total = item.price * item.quantity;

  item.options.forEach(option => (total += option.value * item.quantity));
  return total;
  }

下面是一个带有奶酪“标签”的项目示例。 条件块需要判断是否有两个标签与奶酪相似,然后从第一个 function 中的总和中取出 2 美元

     "item": [
     {
     "id": 1,
     "guid": "1d4aa3b2-c059-4fa7-a751-9bca735e4ea1",
     "thumb": "https://foodorderingapp9309.s3-us-west- 
     1.amazonaws.com/CheesySenstions/menu/CheesePizza.JPG",
     "title": "Cheese",
     "body": "try new cheese pizza",
     "tags": ["pizza"],
     }
     ]

您可以访问forEach循环回调中的项目。

您可以使用计数器来计算具有特定标签的项目数。 这是一个例子:

get totalAmount() {
  let total = 0;
  let numberOfItemsWithCheeseTag = 0;

  this.cart.forEach(item => {
    total += this.getItemTotal(item);

    // Increment the counter if 'cheese' is one of the tags
    if (item.tags.includes('cheese')) {
      numberOfItemsWithCheeseTag += 1; // 
    }
  });

  // Apply the discount if the counter reached a threshold
  if (numberOfItemsWithCheeseTag >= 2) {
    total -= 2;
  }        

  return total;
}

这是一个不同的看法

get totalAmount() {
    let total = this.cart.reduce((t, item) => t + this.getItemTotal(item), 0)
    const count = this.cart.reduce((c, item) => c + item.tags.includes('cheese'), 0)

    if (count >= 2) {
        return total -= 2
    }

    return total
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM