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 elementUI 使用el-select 时 change事件的触发问题
Nov 17 Vue.js
Vue实现点击当前行变色
Dec 14 Vue.js
vue实现购物车的小练习
Dec 21 Vue.js
jenkins自动构建发布vue项目的方法步骤
Jan 04 Vue.js
vue 项目@change多个参数传值多个事件的操作
Jan 29 Vue.js
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 Vue.js
如何理解Vue前后端数据交互与显示
May 10 Vue.js
如何理解Vue简单状态管理之store模式
May 15 Vue.js
vue实现移动端div拖动效果
Mar 03 Vue.js
vue配置型表格基于el-table拓展之table-plus组件
Apr 12 Vue.js
解决vue自定义组件@click点击失效问题
Apr 30 Vue.js
Vue ECharts实现机舱座位选择展示功能
May 15 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 中文处理函数集合
2008/08/27 PHP
PHP中extract()函数的妙用分析
2012/07/11 PHP
PHP实现导出excel数据的类库用法示例
2016/10/15 PHP
解决laravel 5.1报错:No supported encrypter found的办法
2017/06/07 PHP
jQuery 方法大全方便学习参考
2010/02/25 Javascript
JS实现时间格式化的方式汇总
2013/10/16 Javascript
JS文本获得焦点清除文本文字的示例代码
2014/01/13 Javascript
javascript父、子页面交互技巧总结
2014/08/08 Javascript
node.js中的emitter.on方法使用说明
2014/12/10 Javascript
使用jQuery实现input数值增量和减量的方法
2015/01/24 Javascript
基于PHP和Mysql相结合使用jqGrid读取数据并显示
2015/12/02 Javascript
jQuery动画效果图片轮播特效
2016/01/12 Javascript
自己动手制作基于jQuery的Web页面加载进度条插件
2016/06/03 Javascript
AngularJS 表达式详细讲解及实例代码
2016/07/26 Javascript
详解VueJs异步动态加载块
2017/03/09 Javascript
ES6实现的遍历目录函数示例
2017/04/07 Javascript
基于Vue.js 2.0实现百度搜索框效果
2020/12/28 Javascript
webpack3之loader全解析
2017/10/26 Javascript
更改Python命令行交互提示符的方法
2015/01/14 Python
python获取一组汉字拼音首字母的方法
2015/07/01 Python
python difflib模块示例讲解
2017/09/13 Python
python连接数据库的方法
2017/10/19 Python
Python排序搜索基本算法之选择排序实例分析
2017/12/09 Python
python特性语法之遍历、公共方法、引用
2018/08/08 Python
在Django中URL正则表达式匹配的方法
2018/12/20 Python
用Python实现大文本文件切割的方法
2019/01/12 Python
Python 实现敏感目录扫描的示例代码
2020/05/21 Python
CSS3中新增的对文本和字体的设置
2020/02/03 HTML / CSS
Footshop法国:购买运动鞋
2020/01/19 全球购物
金融管理专业毕业生求职信
2014/03/12 职场文书
我们的节日元宵活动方案
2014/08/23 职场文书
绿色校园广播稿
2014/10/13 职场文书
技术员岗位职责范本
2015/04/11 职场文书
2015年小学师德师风建设工作总结
2015/10/23 职场文书
mongodb的安装和开机自启动详细讲解
2021/08/02 MongoDB
JAVA 线程池(池化技术)的实现原理
2022/04/28 Java/Android