Vuex实现简单购物车


Posted in Vue.js onJanuary 10, 2021

本文实例为大家分享了Vuex实现简单购物车的具体代码,供大家参考,具体内容如下

文件结构

Vuex实现简单购物车

App.vue

<template>
 <div id="app">
 <h3>Shopping Cart Demo</h3>
 <hr>
 <h4>Products:</h4>
 <ProductList />
 <hr>
 <h4>My Cart</h4>
 <ShoppingCart />
 </div>
</template>
<script>
import ProductList from '@/components/ProductList';
import ShoppingCart from '@/components/ShoppingCart';
 
export default {
 components: {
 ProductList,
 ShoppingCart
 }
}
</script>

Products.vue

<template>
 <div>
  <ul v-for="item in products" :key="item.id">
  <li>
   {{ item.title }} - {{ item.price }}    库存: {{ item.inventory }}<br>
   <button :disabled="!item.inventory" @click="addToCart(item)">add to cart</button> 
  </li>
  </ul>
 </div>
 
</template>
 
<script>
import { mapGetters, mapActions } from 'vuex';
export default {
 computed: {
 // ...mapGetters('products',{
 // products: 'allProducts'
 // })
 ...mapGetters({
  products: 'products/allProducts'
 })
 },
 methods: {
 ...mapActions('cart',['addToCart'])
 },
 created() {
 this.$store.dispatch('products/getAllProducts');
 }
 
}
</script>

ShoppingCart.vue

<template>
 <div>
 <ul v-for="item in products" :key="item.id">
  <li>{{ item.title }} *{{ item.quantity }}</li>
 </ul>
 <div>total: {{ total }}</div>
 </div>
</template>
<script>
import { mapGetters } from 'vuex';
export default {
 computed: {
 ...mapGetters('cart', {
  products: 'cartProducts',
  total: 'cartTotalPrice'
 })
 }
}
</script>

modules/products.js

import api from '../../api';
 
const state = {
 all: []
}
 
const getters = {
 allProducts: state => state.all
}
 
const actions = {
 // 获取初始商品数据
 getAllProducts({ commit }) {
 api.getProducts(products => commit('setProducts', products));
 }
}
 
const mutations = {
 setProducts(state, products) {
 state.all = products;
 },
 // 减少该商品库存
 decreamentInventory(state, { id }) {
 let productItem = state.all.find(item => item.id === id);
 productItem.inventory --;
 }
}
 
export default {
 namespaced: true,
 state,
 getters,
 actions,
 mutations
}

modules/cart.js

const state = {
 addedList: []
}
 
const getters = {
 cartProducts(state, getters, rootState) {
 return state.addedList.map((item, index) => {
  let productItem = rootState.products.all.find(product => product.id === item.id);
  return {
  title: productItem.title,
  price: productItem.price,
  quantity: item.quantity
  }
 })
 },
 cartTotalPrice(state, getters) {
 return getters.cartProducts.reduce((total, product) => {
  return total + (product.price * product.quantity);
 }, 0);
 }
}
 
const actions = {
 addToCart({ state, commit }, product) {
 if (product.inventory > 0) {
  let productItem = state.addedList.find(item => item.id === product.id);
  if (productItem) {
  commit('increamentItemQuantity', productItem);
  } else {
  commit('pushItemToCart', product);
  }
  commit('products/decreamentInventory', product, { root: true });
 }
 }
}
 
const mutations = {
 // 增加购物车中同等商品的数量
 increamentItemQuantity(state, { id }) {
 let productItem = state.addedList.find(item => item.id === id);
 productItem.quantity ++;
 },
 // 将商品加入购物车
 pushItemToCart(state, { id }) {
 state.addedList.push({
  id,
  quantity: 1
 })
 },
 
}
 
export default {
 namespaced: true,
 state,
 getters,
 actions,
 mutations
}

store/index.js

import Vue from 'vue';
import Vuex from 'vuex';
import cart from './modules/cart';
import products from './modules/products';
 
Vue.use(Vuex);
 
export default new Vuex.Store({
 modules: {
 cart,
 products
 }
});

main.js

import Vue from "vue";
import App from "@/components/App.vue";
import store from "@/store";
 
Vue.config.productionTip = false;
 
new Vue({
 store,
 render: h => h(App)
}).$mount("#app");

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
详解vue 组件注册
Nov 20 Vue.js
vue中activated的用法
Jan 03 Vue.js
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 Vue.js
vue实现同时设置多个倒计时
May 20 Vue.js
HTML+VUE分页实现炫酷物联网大屏功能
May 27 Vue.js
vue-router中hash模式与history模式的区别
Jun 23 Vue.js
Vue3.0 手写放大镜效果
Jul 25 Vue.js
Vue+TypeScript中处理computed方式
Apr 02 Vue.js
教你部署vue项目到docker
Apr 05 Vue.js
vue实现Toast组件轻提示
Apr 10 Vue.js
vue3种table表格选项个数的控制方法
Apr 14 Vue.js
Vue实现一种简单的无限循环滚动动画的示例
Jan 10 #Vue.js
基于vuex实现购物车功能
Jan 10 #Vue.js
antdesign-vue结合sortablejs实现两个table相互拖拽排序功能
Jan 08 #Vue.js
vue-quill-editor插入图片路径太长问题解决方法
Jan 08 #Vue.js
vue编写简单的购物车功能
Jan 08 #Vue.js
解决vue使用vant轮播组件swipe + flex时文字抖动问题
Jan 07 #Vue.js
vuex的使用和简易实现
Jan 07 #Vue.js
You might like
php加水印的代码(支持半透明透明打水印,支持png透明背景)
2013/01/17 PHP
Laravel中encrypt和decrypt的实现方法
2017/09/24 PHP
javascript下有关dom以及xml节点访问兼容问题
2007/11/26 Javascript
仅IE6/7/8中innerHTML返回值忽略英文空格的问题
2011/04/07 Javascript
Jquery中扩展方法extend使用技巧
2014/08/24 Javascript
js生成的验证码的实现与技术分析
2014/09/17 Javascript
js检测判断日期大于多少天的方法
2015/05/04 Javascript
AngularJS ng-controller 指令简单实例
2016/08/01 Javascript
JS实现JSON.stringify的实例代码讲解
2017/02/07 Javascript
详细AngularJs4的图片剪裁组件的实例
2017/07/12 Javascript
利用Ionic2 + angular4实现一个地区选择组件
2017/07/27 Javascript
JS获取数组中出现次数最多及第二多元素的方法
2017/10/27 Javascript
JS计算输出100元钱买100只鸡问题的解决方法
2018/01/04 Javascript
koa2使用ejs和nunjucks作为模板引擎的使用
2018/11/27 Javascript
jQuery实现每日秒杀商品倒计时功能
2019/09/06 jQuery
node 版本切换的实现
2020/02/02 Javascript
可能是最全面的 Python 字符串拼接总结【收藏】
2018/07/09 Python
python中while和for的区别总结
2019/06/28 Python
python多继承(钻石继承)问题和解决方法简单示例
2019/10/21 Python
Keras 实现加载预训练模型并冻结网络的层
2020/06/15 Python
python 实现两个npy档案合并
2020/07/01 Python
用HTML5 实现橡皮擦的涂抹效果的教程
2015/05/11 HTML / CSS
Ratchet 模态框的实现
2020/08/19 HTML / CSS
linux系统都有哪些运行级别
2016/03/26 面试题
普通员工辞职信
2014/01/17 职场文书
《藏戏》教学反思
2014/02/11 职场文书
求职信模板
2014/05/23 职场文书
宣传工作经验材料
2014/06/02 职场文书
习近平在党的群众路线教育实践活动总结大会上的讲话全文
2014/10/25 职场文书
个人党性分析材料
2014/12/19 职场文书
2015个人半年总结范文
2015/03/09 职场文书
婚礼男方父母答谢词
2015/09/29 职场文书
少先队大队委竞选口号
2015/12/25 职场文书
JS如何实现基于websocket的多端桥接平台
2021/05/14 Javascript
python 判断文件或文件夹是否存在
2022/03/18 Python
JavaWeb实现显示mysql数据库数据
2022/03/19 Java/Android