vue.js - 无法在 vuex 中更新购物车商品数量
问题描述
我一直被困在 vuex 商店,我不知道如何更新购物车项目数量,添加到产品工作正常但是我们将如何更改购物车项目的数量,任何人都可以告诉我,
动作.js
export const updateCart = ({ commit, dispatch }, { product, quantity }) => {
commit('UPDATE_CART', { product, quantity });
Cart.update({ product_id: product.id, 数量 });
}
突变.js
export const UPDATE_CART = (state, { product, quantity }) => {
let productInCart = state.cart.find(item => {
return item.product.id === product.id;
});
if (productInCart) {
productInCart.quantity += quantity;
return;
}
state.cart.push({
product,
quantity
})
}
购物车.vue
<input class="quantity-spinner" type="text" @keyup="updateCart(item,$event)" :value="item.quantity" name="quantity">
methods: {
goToRoute(name){
this.$router.push(this.$baseUrl+'/'+name)
},
...mapActions("cart", [
"removeProductFromCart",
"clearCartItems",
"getCartItems",
"updateCart"
]),
updateCart(product,e)
{
this.quantity = e.target.value;
this.updateCart({
product:product,
quantity: parseInt(this.quantity)
});
}
},
解决方案
要更新商店,您需要调度操作。
购物车.vue
updateCart(product, e)
{
this.quantity = parseInt(e.target.value);
this.$store.dispatch('UPDATE_CART',{ product, quantity: this.quantity })
}
推荐阅读
- sql - 使用 T-SQL 解析 URL 参数
- javascript - 使用 Vue JS 将“axios”传递给“Swiper”
- c++ - C++ 中的堆是包含类和结构对象还是只包含指针?
- github - 在 GitHub 上更改存储库语言
- python - 如何获得 7x7 矩阵 numpy
- java - Kotlin 或 Java 中恒定时间复杂度 O(1) 的 Concat 链表
- ruby-on-rails - 如何洗牌每个分类单元检索到的狂欢产品
- haskell - 无法返回可能导致 IO Monad
- r - 对两个 NA 之间的元素求和
- python - 在 Google Colab 上进行培训,Unity 环境与 Multiprocessing.py 挂起