关于Vuex的初步使用
store.js文件中定义各个访问状态和方法
import Vue from "vue"
import Vuex from "vuex" Vue.use(Vuex) const state = { //定义访问状态对象
count : 44
} const mutations = { //定义触发状态对象方法,传入state整个对象
jia(state) {
state.count ++
}
} const getters = { //类似计算属性,对state的数据进行复杂的逻辑计算,使用return返回结果
count : function (state){
return state.count += 100
}
} const actions = { //异步执行方法,传入参数context,等同于整个store
jianplus (context) {
context.commit("jia",10) //调用mutations中的方法并传参
} testplus ({commit}) { //简写方式,使用{} 单独传入mutations对象
commit(‘jian’) //调用mutations中的方法
} three({commit,dispatch}){ //使用dispatch调用actions的方法
return dispatch('testplus').then(()=>{
commit('jianplus')
})
}
}, Const moduleA = { //定义一个模块,引入各个状态对象或方法
state,
mutations,
getters,
actions
} export default new Vuex.Store ({ //没有使用模块时的写法
state,
mutations,
gettrts,
actions
}) // export default new Vuex.Store ({ //使用模块时的写法
// modules : {
// a : moduleA //引入定义模块
// }
// })
一、state 定义访问状态 定义的是常量
如何在HTML中访问:当未引入 mapState时,可通过$store去访问 引入时按照正常的变量使用
<h1>{{$store.state.count}}</h1> //通过$store去访问
在vue文件中的定义:在计算属性computed位置进行引用,使用mapState
import {mapState } from ‘Vuex’ //引入 mapState
export default {
name: 'test', data: () => ({
test: '',
}), methods: { }, // computed: mapState([ //直接使用state中定义的count 注意这里是一个数组
// "count"
// ]) computed: mapState({ //对state中定义的count做运算后再使用 注意这里是一个对象
count : state => state.count+1 }) }
二、mutations 定义触发访问状态的方法 触发方法为同步执行
如何使用:跟事件触发方法一样跟在各种事件之后,通过commit方法触发
<button type="button" @click="$tore.commit(“jia”)"></button>
如何传参:括号内第一个值为方法名,后面为传入参数,传入的参数可以为一个对象
<button type="button" @click="$tore.commit(“jia”,10)"></button>
在vue文件中的定义:在定义方法methods位置进行引用,使用mapMutations
import {mapState,mapMutations} from ‘Vuex’ //引入 mapMutations
export default {
name: 'test', data: () => ({
test: '',
}), methods:mapMutations([ //定义mutations中的各个方法
‘jia’,
‘jian’
]) computed: mapState({ //对state中定义的count做运算后再使用
count : state => state.count+1
})
}
三、getters 类似于计算属性 一般在对访问状态内的数据做复杂运算时使用
在vue文件中的定义:在计算属性computed位置进行引用,使用mapGetters
computed : { //vue文件中只能有一个computed,同时定义state时,需要改变写法
...mapState ({ //注意使用...
"count”
}), count () { //调用getters中的count方法,将值return出去
return this.$store.getters.count
}
简化写法:引入mapGetters
import {mapState,mapMutations,mapGetters} from ‘Vuex’ //引入 mapGetters
export default {
name: 'test', data: () => ({
test: '',
}), methods:mapMutations([ //定义mutations中的各个方法
‘jia’,
‘jian’
]) computed : { //vue文件中只能有一个computed,同时定义state时,需要改变写法
...mapState ({ //注意使用...
"count”
}), ...mapGetters([ //调用getters中的count
"count”
])
}
}
四、actions 异步触发方法
在vue文件中的定义:在定义方法methods位置进行引用,使用mapActions 也可以通过dispatch方法触发
import {mapState,mapMutations,mapGetters,mapActions} from ‘Vuex’ //引入 mapActions
export default {
name: 'test', data: () => ({
test: '',
}), methods:{
...mapMutations([
‘jia’,
‘jian’
]), ...mapActions([ //引入actions中定义的jiaplus方法
‘jiaplus’
])
} computed : {
...mapState ({
"count”
}), ...mapGetters([
"count”
])
}
}
<button type="button" @click="$tore.dispatch(“jiaplus”)"></button>
dispatch代表的是actions的整个对象,我们可以通过在其中一个actions中传入dispatch触发其他的actions方法,会有一个返回值
actions: {
actionA ({ commit }) {
return new Promise((resolve, reject) => {
setTimeout(() => {
commit('someMutation')
resolve()
}, 1000)
})
}, actionB ({ dispatch, commit }) {
// 组合,传入dispatch 调用actions的其他方法
return dispatch('actionA').then(() => {
commit('someOtherMutation')
})
}
}
五、modules 模块组 当有多个store对象时使用
关于Vuex的初步使用的更多相关文章
- 对Vuex的初步了解
文章转载于:http://www.cnblogs.com/wisewrong/p/6344390.html 在 Vue.js 的项目中,如果项目结构简单, 父子组件之间的数据传递可以使用 props ...
- Vue全家桶(Vue-cli、Vue-route、vuex)
摘要 学习本篇之前要具备一定的vue基础知识,可以先看一下Vue基础(环境配置.内部指令.全局API.选项.内置组件) 1.Vue-cli Vue-cli是vue官方出品的快速构建单页应用的脚手架,这 ...
- Vuex入门(5)—— 为什么要用Action管理异步操作
Action 类似于 mutation,不同在于: 1.Action 提交的是 mutation,而不是直接变更状态. 2.Action 可以包含任意异步操作. 官方给的定义我没什么意见,事实上我通过 ...
- [vuex]——使用vuex解决模块间传值问题
二月的第四个周末,在家.受寒流的影响,深圳天气持续冰冻了好几天,天冷人就变得懒动,迷迷糊糊睡到了快十点,终于在饥饿的催促下起床. 和妹子吃完粥后,百无聊赖.透过窗户,发现太阳依旧没有露头的打算,我们也 ...
- 关于vuex的理解
刚开始学vue的时候,看到很多项目都有用vuex,抱着一种好奇的心态去看下vuex的官方文档,如下: Vuex官方文档 Vuex 是什么?Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 ...
- 关于vuex
希望初学者可以初步理解vuex的日志: 示意图: 一.图例: 1.Vue Components:Vue组件.HTML页面上,负责接收用户操作等交互行为,执行dispatch方法触发对应action进行 ...
- 实现一个简易版的vuex持久化工具
背景 最近用uni-app开发小程序项目时,部分需要持久化的内容直接使用vue中的持久化插件貌似不太行,所以想着自己实现一下类似vuex-persistedstate插件的功能,想着功能不多,代码量应 ...
- vue 快速入门 系列 —— 初步认识 vue
其他章节请看: vue 快速入门 系列 初步认识 vue vue 是什么 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架. 所谓渐进式,就是你可以一步一步.有阶段 ...
- 初步认识微前端(single-spa 和 qiankun)
初步认识微前端 微前端是什么 现在的前端应用,功能.交互日益复杂,若只由一个团队负责,随着时间的推进,会越来越庞大,愈发难以维护. 微前端这个名词,第一次提出是在2016年底.它将微服务(将单一应用程 ...
随机推荐
- Webpack 2 视频教程 017 - Webpack 2 中分离打包项目代码与组件代码
原文发表于我的技术博客 这是我免费发布的高质量超清「Webpack 2 视频教程」. Webpack 作为目前前端开发必备的框架,Webpack 发布了 2.0 版本,此视频就是基于 2.0 的版本讲 ...
- 关于recycleview 滑动item变长(item变形)问题
昨天在做项目的时候出现了bug,表现是在滑动的时候,整个item会被拉长了,松手后就回归正常大小了, 出现这个的主要原因是因为你的item布局中最大的那个根布局是 match_parent状态,因此导 ...
- ZJOI 2015 诸神眷顾的幻想乡
题目描述 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看.幽香当然也非常 ...
- ADO.NET访问数据库
1:ADO.NET数据库的方法和技术 2:ADO.NET的主要组成: 1>DataSet(数据集)-----独立于数据间的数据访问 2>.NETFramework(数据提供程序)----- ...
- ${param.name}和${name}的区别
${param.name} == request.getParam("name") ${name} == request.getAttribute("name" ...
- chrome console的使用 : 异常和错误的处理 – Break易站
本文内容来自:chrome console的使用 : 异常和错误的处理 – Break易站 利用 Chrome DevTools 提供的工具,您可以修复引发异常的网页和在 JavaScript 中调试 ...
- php 抽象类abstract
程序中,有些类的作用只是用来继承,无须实例化: 为了满足类的这种需求,php提供了抽象类的概念 ,关键词abstract: 抽象类原则: 抽象类不能被实例化 有抽象方法的类一定是抽象类:类必须要abs ...
- iOS SQLite解密之SQLCipher
开门见山,本文主要讲在Mac下使用SQLCipher编译解密数据库文件方法,iOS项目集成SQLCipher自己可以百度,网上帖子很多. 官方集成文档:https://www.zetetic.net/ ...
- jdk8新特性(文章推荐)
文章推荐 jdk9都已经出来了,虽然很多项目都已经使用jdk8,但是很少会用到jdk8中的新特性.本人经常用的到也就是使用Stream,Lambda,但也仅仅是使用,基本不知道什么Function,C ...
- Spark 学习笔记大纲
Spark 内核 第28课:Spark天堂之门解密 (点击进入博客)从 SparkContext 创建3大核心对象开始到注册给 Master 这个过程中的源码鉴赏 第29课:Master HA彻底解密 ...