这篇文章主要介绍如何用vuex实现购物车的增加减少移除,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
1.store.js(公共的仓库)
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({
state: {
carList: [] //购物车的商品
},
mutations: {
// 加
addCar(state, params) {
let CarCon = state.carList;
// 判断如果购物车是否有这个商品,有就只增加数量,否则就添加一个
// some 只要有一个isHas为true,就为true
let isHas = CarCon.some((item) => {
if (params.id == item.id) {
item.num++;
return true;
} else {
return false;
}
})
if (!isHas) {
let obj = {
"id": params.id,
"title": params.title,
"price": params.price,
"num": 1,
}
this.state.carList.push(obj)
}
},
// 减
reducedCar(state,params){
let len=state.carList.length;
for(var i=0;i<len;i++){
if(state.carList[i].id==params.id){
state.carList[i].num--
if(state.carList[i].num==0){
state.carList.splice(i,1);
break;
}
}
}
},
//移出
deleteCar(state,params){
let len=state.carList.length;
for(var i=0;i<len;i++){
if(state.carList[i].id==params.id){
state.carList.splice(i,1);
break;
}
}
},
// 初始化购物车,有可能用户一登录直接进入购物车
// initCar(state, car) {
// state.carList = car
// },
},
actions: {
// 加
addCar({ commit }, params) {
// console.log(params) //点击添加传过来的参数
// 使用setTimeout模拟异步获取购物车的数据
setTimeout(function () {
let result = 'ok'
if (result == 'ok') {
// 提交给mutations
commit("addCar", params)
}
}, 100)
},
// 减
reducedCar({ commit }, params) {
// console.log(params) //点击添加传过来的参数
// 使用setTimeout模拟异步获取购物车的数据
setTimeout(function () {
let result = 'ok'
if (result == 'ok') {
// 提交给mutations
commit("reducedCar", params)
}
}, 100)
},
// 移出
deleteCar({ commit }, params) {
// console.log(params) //点击添加传过来的参数
// 使用setTimeout模拟异步获取购物车的数据
setTimeout(function () {
let result = 'ok'
if (result == 'ok') {
// 提交给mutations
commit("deleteCar", params)
}
}, 100)
}
// initCar({ commit }) {
// setTimeout(function () {
// let result = 'ok'
// if (result == 'ok') {
// // 提交给mutations
// commit("initCar", [{
// "id": 20193698,
// "title": '我是购物车原来的',
// "price": 30,
// "num": 100,
// }])
// }
// }, 100)
// }
},
getters: {
//返回购物车的总价
totalPrice(state) {
let Carlen = state.carList;
let money = 0;
if (Carlen.length != 0) {
Carlen.forEach((item) => {
money += item.price * item.num
})
return money;
} else {
return 0;
}
},
//返回购物车的总数
carCount(state) {
return state.carList.length
}
},
})
2. list.vue(商品列表)
<template>
<!-- 商品列表 -->
<div id="listBox">
<!-- -->
<router-link :to="{path:'/car'}" >跳转到购物车</router-link>
<el-table :data="tableData" border >
<el-table-column fixed prop="id" align="center" label="商品id"></el-table-column>
<el-table-column prop="title" align="center" label="商品标题"></el-table-column>
<el-table-column prop="price" align="center" label="商品价格"></el-table-column>
<el-table-column label="操作" align="center">
<template slot-scope="scope">
<el-button @click="addCar(scope.row)" type="text" size="small">加入购物车</el-button>
</template>
</el-table-column>
</el-table>
</div>
</template>
<script>
export default {
name: "listBox",
data() {
return {
tableData: [] //商品列表
};
},
methods: {
// 初始化商品列表
initTable(){
this.$gAjax(`../static/shopList.json`)
.then(res => {
console.log(res)
this.tableData=res;
})["catch"](() => {});
},
// 加入购物车
addCar(row){
// console.log(row)
// 提交给store里面actions 由于加入购物车的数据要同步到后台
this.$store.dispatch('addCar',row)
}
},
mounted () {
this.initTable()
}
};
</script>
<style>
#listBox {
width: 900px;
margin: 0 auto;
}
</style>
3. car.vue(购物车)
<template>
<!-- 购物车 -->
<div id="carBox">
<!-- 商品总数 -->
<h3 >合计:总共{{count}}个商品,总价{{totalPrice}}元</h3>
<p v-if="count==0">空空如也!·······</p>
<div v-else>
<el-table :data="carData" border >
<el-table-column fixed prop="id" align="center" label="商品id"></el-table-column>
<el-table-column prop="title" align="center" label="商品标题"></el-table-column>
<el-table-column prop="price" align="center" label="商品价格"></el-table-column>
<el-table-column label="操作" align="center">
<template slot-scope="scope">
<el-button @click="reduceFun(scope.row)" type="text" size="small">-</el-button>
<span >{{scope.row.num}}</span>
<el-button @click="addCar(scope.row)" type="text" size="small">+</el-button>
<el-button @click="deleteFun(scope.row)" type="text" size="small">删除</el-button>
</template>
</el-table-column>
</el-table>
</div>
</div>
</template>
<script>
export default {
name: "carBox",
data() {
return {};
},
computed: {
//购物车列表
carData() {
return this.$store.state.carList;
},
//商品总数
count() {
return this.$store.getters.carCount;
},
//商品总价
totalPrice() {
return this.$store.getters.totalPrice;
}
},
methods: {
// 增加数量
addCar(row){
this.$store.dispatch('addCar',row)
},
// 减数量
reduceFun(row){
this.$store.dispatch('reducedCar',row)
},
// 删除
deleteFun(row){
this.$store.dispatch('deleteCar',row)
}
// 用户首次登录请求购物车的数据
// initCar(){
// this.$store.dispatch('initCar')
// }
},
created () {
// this.initCar();
},
mounted() {}
};
</script>
<style>
#carBox {
width: 900px;
margin: 0 auto;
}
</style>
以上是如何用vuex实现购物车的增加减少移除的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。