用vuex写了一个购物车H5页面的示例代码
用vuex写了一个购物车H5页面的示例代码:https://www.jb51.net/article/152008.htm
通过购物车的一个案列,把vuex学习了一篇。
vuex概念浅谈
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。简单的来说,就是数据共用,对数据集中起来进行统一的管理。
如果您的应用够简单,您最好不要使用 Vuex。一个简单的 global event bus 就足够您所需了。但是,如果您需要构建是一个中大型单页应用,您很可能会考虑如何更好地在组件外部管理状态,Vuex 将会成为自然而然的选择。
核心概念主要有这些
State
Vuex 使用单一状态树——是的,用一个对象就包含了全部的应用层级状态,将所需要的数据写放这里,类似于data。
Getter
有时候我们需要从 store 中的 state 中派生出一些状态,使用Getter,类似于computed。
Mutation
更改 Vuex 的 store 中的状态的唯一方法,类似methods。
Action
Action 提交的是 mutation,而不是直接变更状态,可以包含任意异步操作,这里主要是操作异步操作的,使用起来几乎和mutations方法一模一样,类似methods。
Module
当应用变得非常复杂时,store 对象就有可能变得相当臃肿。Vuex 允许我们将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action、getter、甚至是嵌套子模块。
vuex
首先需要创建一个Vue项目
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
# 全局安装 vue-cli $ npm install --global vue-cli # 创建一个基于 webpack 模板的新项目 $ vue init webpack my-project # 安装依赖,走你 $ cd my-project $ npm install $ npm run dev |
安装vuex
1
|
npm install --save vuex |
对vuex进行配置
1.创建一个store文件夹
2.在store文件夹下创建如图的一系列js文件
3.在main.js文件中引入上面创建的store.js
1
2
3
4
5
6
7
8
9
10
11
12
13
|
import store from './store' new Vue({ el: '#app' , store, //将store暴露出来 components: { App }, template: '<App/>' }) |
4.将要存放的数据写在state对象中,state则存写在index.js文件中。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
import Vue from 'vue' import Vuex from 'vuex' import mutations from './mutations' import actions from './actions' import getters from './getters' import shop from './modules/shop' Vue.use(Vuex) const state = { goods: [ { id: '0' , name: 'vivo-X20Plus屏幕指纹版' , hint: '逆光也清晰,照亮你的美' , price: 3596.00, num: 0, img: require( '../assets/v.jpg' ) }, { id: '1' , name: '华为mate10Plus' , hint: '真正的人工智能芯片' , price: 4999.00, num: 0, img: require( '../assets/h.jpeg' ) }, { id: '2' , name: '华为mate10Plus' , hint: '真正的人工智能芯片' , price: 4999.00, num: 0, img: require( '../assets/v.jpg' ) } ], totalPrice: 0.00, totalNum: 0 } export default new Vuex.Store({ state, mutations, actions, getters, modules: { shop //shop模块 } }) |
5.将改变state原始数据的方法写在mutation.js文件中,可以使用常量替代 Mutation 事件类型,用不用常量取决于你——在需要多人协作的大型项目中,这会很有帮助。可以让你的代码合作者对整个 app 包含的 mutation 一目了然。
1
2
3
4
5
|
// 使用常量,这是mutation-type.js文件 export const ADD_CART = 'ADD_CART' export const REDUCE_CART = 'REDUCE_CART' |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
// 这是mutation.js文件 import { ADD_CART, REDUCE_CART } from './mutation-types.js' export default { [ADD_CART] (state, id) { state.goods[id].num++ state.totalNum++ state.totalPrice += state.goods[id].price // console.log(state.totalPrice) }, [REDUCE_CART] (state, id) { if (state.goods[id].num > 0) { state.goods[id].num-- state.totalNum-- state.totalPrice -= state.goods[id].price } } } |
6.对state数据派生出一些状态,例如需要知道商品的个数
1
2
3
4
5
6
7
8
|
const getters = { goods_obj: state => state.goods, goods_length: state => state.goods.length } export default getters |
7.使用vuex,获取数据,方法。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
<template> <div class= "hello" > <ul class= "shop_container" > <li v- for = "item in $store.state.goods" :key= "item.id" class= "shop_container_li" > <div class= "shop_img" > <img :src= "item.img" alt= "" width= "100%" height= "100%" /> </div> <div class= "shop_detail" > <p>{{item.name}}</p> <p>{{item.hint}}</p> <p>¥{{item.price}}</p> <p> <span class= "shop_reduce" @click= "reduce_num(item.id)" >-</span> <span class= "shop_num" >{{item.num}}</span> <span class= "shop_add" @click= "add_num(item.id)" >+</span> </p> </div> </li> </ul> <div class= "foot" > <div class= "total_price" > <span>合计:¥{{totalPrice}}</span> </div> <div class= "total_num" :class= "{payment: totalNum}" > <span>去结账:{{totalNum}}</span> </div> </div> </div> </template> <script> import {mapState, mapMutations, mapGetters} from 'vuex' export default { name: 'HelloWorld' , data () { return { } }, created () { // console.log(this.goods) // console.log(this.goods_obj) // console.log(this.goods_length) // console.log(this.$store.state.shop) // 模块化 Vuex允许我们将 store 分割成模块(module)每个模块拥有自己的 state、mutation、action、getter、 }, computed: { ...mapState([ // 获取state中的数据可以通过mapState辅助函数获取,也可以直接获取 例:this.$store.state.goods 'goods' , 'totalPrice' , 'totalNum' ]), ...mapGetters([ 'goods_obj' , 'goods_length' ]) }, methods: { ...mapMutations([ // 获取mutation中的方法可以通过mapMutations 辅助函数获取,也可以直接获取。 'ADD_CART' // 'REDUCE_CART' ]), reduce_num (id) { // this.REDUCE_CART(id) this .$store.commit( 'REDUCE_CART' , id) //也可以直接获取 }, add_num (id) { this .ADD_CART(id) //通过mapMutations 辅助函数获取 } } } </script> |
8.假如数据过多,复杂,可以进行模块化来开发,可以将上述的state,mutation,action等可以同时写在shop.js文件中,此时shop就是一个模块了。
总结
若数据不是很多,也不复杂,我们也可以在构造vue实例data中存放我们所需要的共用数据。一旦数据较多,复杂,vuex是一个非常不错的选择,对于状态管理。
努力学习中,希望能和大神一起。
github地址:https://github.com/flym1013/vuexDemo
效果预览地址: https://flym1013.github.io/vuexDemoBuild/
效果图预览
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
用vuex写了一个购物车H5页面的示例代码的更多相关文章
- 领导让我重新做一个微信H5页面!
leader:我们需要做一个微信H5页面,效果如图,功能如描述,时间越快越好. 需求是不是很简单呢?2015-11-24 12:44:00文末有最新更新 背景描述 前几天微信转发相关项目开发后,这是第 ...
- vue-实现一个购物车结算页面
这是路由之间的跳转,传递值最好采用传参,而不是用$emit和$on,不起作用 如果实在一个页面中的兄弟组件,可以使用$emit和$on 中间件,eventBus.js 放在components目录下面 ...
- 微信JS-SDK DEMO页面和示例代码
<?php require_once "jssdk.php"; $jssdk = new JSSDK("yourAppID", "yourApp ...
- jsp页面使用javascript添加页面元素示例代码
<body> <input type="button" value="test" onclick="javascript:a( ...
- 用java编写一个微博登陆页面
上次也写了一个微博登陆页面,不过功能还不够完善.今天重新完善了一些功能,分享出来给大家. 基本功能如下: (1)具有类似新浪微博的用户注册图形界面. (2)使用用户名或手机号注册,注册时需要提供新密码 ...
- VUE的一个数据绑定与页面刷新相关的bug
1.场景: N层嵌套的循环查询业务场景,框架是vue.其中在最后一层查完之后,还需要查其中每一项的两个属性,类型都是列表.查完之后将其赋值给一个变量用于页面展示.代码如下: (1)异常代码: getS ...
- c# .Net :Excel NPOI导入导出操作教程之List集合的数据写到一个Excel文件并导出
将List集合的数据写到一个Excel文件并导出示例: using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using System;using Sys ...
- 自己写的一个 java swing 的闹钟
上一周新入职,把代码down下来之后,领导和我讲了一些大概的业务以及代码流程(领导是技术出身),领导让我自己先看看代码,然后我看了两天,觉得已经完全可以接任务了,但是领导却迟迟没有分配任务给我,虽然他 ...
- vue为app做h5页面,如何做到同域名对应不同版本的h5代码
1.当我们在做混合开发的时候,app端可以有无数多个版本,一般情况h5页面只有一套代码.应该如何部署多套代码呢? 2.业务场景 当出现这种情况的时候,其实前端可以部署多套代码.比如: www.stat ...
随机推荐
- JS同步执行代码
new Promise(function(){initAppToken()}).then(()=> getApps(this.pageInfo).then ...
- apache重写规则简单理解
1.前提:开启apache重写,并把httpd.conf里的相关的AllowOverride denied改为AllowOverride all 2.重写规则可写在项目根目录的.htaccess文件或 ...
- php函数漏洞
1.ereg — 正则表达式匹配 此函数遇 %00 截断. <?php $a = $_GET['pwd']; var_dump(ereg ("^[0-9]+$", $a)); ...
- 在MySQL登录时出现Access denied for user 'root'@'localhost' (using password: YES) 拒绝访问,并可修改MySQL密码
这两天装了一个mysql 5.7数据库,但是在本地dos登陆不上去,报错Access denied for user 'root'@'localhost'(using password:YES): 也 ...
- vue+java后台通信报403,cors解决跨域问题(该贴说的不是很清楚,不过大概如此,可再去网上查相关内容)
前端是vue2.0,网络请求用的是axios,后端是springboot2.0 用axios向后端发送post请求,结果得到一个403无权限的错误,莫名其妙啊,我明明发送的是post请,但在chrom ...
- hdu 6205: card card card【输入挂】
题目链接 感谢 http://blog.csdn.net/txgang/article/details/77568491 以下供参考 getchar读入法 2683MS FastIO法 MX=1e2 ...
- python实现Restful服务 (基于flask)(1)
参考:https://www.jianshu.com/p/6ac1cab17929 参考:https://www.cnblogs.com/alexyuyu/p/6243362.html 参考:http ...
- BZOJ 4836: [Lydsy1704月赛]二元运算 分治FFT
Code: #include<bits/stdc++.h> #define ll long long #define maxn 500000 #define setIO(s) freope ...
- C#仿QQ皮肤-Label与ListBox 控件实现----寻求滚动条的解决方案
大家还是先来看看效果吧 这次之所以一次写两个控件,其实主要是因为Label控件实在是太简单了没有必要放放一个文章里写,所以就一次性来了.Label控件我就不再多说了,我直接把代码贴一下吧因为就几行代码 ...
- [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.j2ee.server:lovemu' did not find a matching property.
[SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.js ...