vuex的简单应用
程序员文章站
2022-04-24 10:45:17
...
vuex的简单应用
一、简介
本文介绍了对vuex的理解以及将上一篇文章改为vuex统一管理
二、vuex理解
1)、vuex是什么
vuex为状态管理,集中管理组件的共用状态以及更新状态的函数等,可以理解为一个全局仓库
2)、vuex的属性
- state :state为一个存放状态的对象
- setters :setters为一个存放计算属性的对象
- actions :actions为一个存放事件回调函数的对象
- mutations :mutations为一个存放状态更新函数的对象
3)、vuex的优点
vuex最明显的优点是将状态和函数统一管理,避免了其在组件之中的传来传去
4)、vuex的框图
组件在state或getters中获取状态,当组件触发事件时,给actions派发事件,actions再请求mutations中的状态更新函数,最终改变状态
三、vuex应用
将上文的评论系统改为vuex管理
1)、vuex的注册
在根src目录下创建一个store文件夹,在其中的index.js中注册,
基本上是一样的,不需要改动
import Vue from 'vue'
import Vuex from 'vuex'
import state from './state.js'
import actions from './actions.js'
import mutations from './mutations.js'
import getters from './getters.js'
Vue.use(Vuex);
export default new Vuex.Store({
state,
actions,
mutations,
getters
})
记得还要再main.js入口文件中引用
import store from './store'
2)、vuex的使用
1、状态统一管理
将多组件共用的data放到state.js文件中,若有共用的计算属性,要放到getters.js中统一管理
export default {
comments: [
{
name:'Bob',
content:'Vue大法好'
},
{
name:'Kat',
content:'Vue还不错'
},
{
name:'Jack',
content:'Vue so eazy'
}
]
}
2、更新的统一管理
上文中有两个更新,增加评论和删除评论,并将操作函数都放到了父组件中,使用vuex后,则不需要将数据和函数传送。根据流程图的步骤,完成操作
- 在组件的事件函数中给action分发事件,除了传函数名以外,还要将要处理的数据传送过去
this.$store.dispatch('addComment',comment);
- 在action.js中请求mutation处理状态(注意commit中传送的数据无论是什么类型,都要包装成一个对象)
export default {
addComment({commit},comment) { //添加评论请求
commit('ADDCOMMENT',{comment})
},
deleteComment({commit},index) { //删除评论请求
commit('DELETECOMMENT',{index})
}
}
- 在mutation.js中处理数据
export default {
ADDCOMMENT(state,{comment}) { //添加评论
state.comments.unshift(comment);
},
DELETECOMMENT(state,{index}) { //删除评论
state.comments.splice(index,1);
}
}
推荐阅读
-
cakephp setFlash()及flash()方法都不起作用,setFlash()的具体用法及简单案例,该如何处理
-
一个session的报错问题 很简单 谁帮忙解释下
-
JavaScript中的闭包及应用场景介绍
-
Flask学习之旅--用 Python + Flask 制作一个简单的验证码系统
-
PHP中使用curl伪造IP的简单方法,phpcurl伪造ip_PHP教程
-
用PHP向数据库中实现简单的增删改查(纯代码,待完善),php增删
-
一个简单的模板引擎类,此类仅作研究并不完善,希望有朋友一起参与学习研究
-
浅解伪静态在phpWind中的应用_PHP教程
-
在Windows上的MySQL UDF开发应用_MySQL
-
通过PHP CLI实现简单的数据库实时监控调度