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的初步使用的更多相关文章

  1. 对Vuex的初步了解

    文章转载于:http://www.cnblogs.com/wisewrong/p/6344390.html 在 Vue.js 的项目中,如果项目结构简单, 父子组件之间的数据传递可以使用  props ...

  2. Vue全家桶(Vue-cli、Vue-route、vuex)

    摘要 学习本篇之前要具备一定的vue基础知识,可以先看一下Vue基础(环境配置.内部指令.全局API.选项.内置组件) 1.Vue-cli Vue-cli是vue官方出品的快速构建单页应用的脚手架,这 ...

  3. Vuex入门(5)—— 为什么要用Action管理异步操作

    Action 类似于 mutation,不同在于: 1.Action 提交的是 mutation,而不是直接变更状态. 2.Action 可以包含任意异步操作. 官方给的定义我没什么意见,事实上我通过 ...

  4. [vuex]——使用vuex解决模块间传值问题

    二月的第四个周末,在家.受寒流的影响,深圳天气持续冰冻了好几天,天冷人就变得懒动,迷迷糊糊睡到了快十点,终于在饥饿的催促下起床. 和妹子吃完粥后,百无聊赖.透过窗户,发现太阳依旧没有露头的打算,我们也 ...

  5. 关于vuex的理解

    刚开始学vue的时候,看到很多项目都有用vuex,抱着一种好奇的心态去看下vuex的官方文档,如下: Vuex官方文档 Vuex 是什么?Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 ...

  6. 关于vuex

    希望初学者可以初步理解vuex的日志: 示意图: 一.图例: 1.Vue Components:Vue组件.HTML页面上,负责接收用户操作等交互行为,执行dispatch方法触发对应action进行 ...

  7. 实现一个简易版的vuex持久化工具

    背景 最近用uni-app开发小程序项目时,部分需要持久化的内容直接使用vue中的持久化插件貌似不太行,所以想着自己实现一下类似vuex-persistedstate插件的功能,想着功能不多,代码量应 ...

  8. vue 快速入门 系列 —— 初步认识 vue

    其他章节请看: vue 快速入门 系列 初步认识 vue vue 是什么 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架. 所谓渐进式,就是你可以一步一步.有阶段 ...

  9. 初步认识微前端(single-spa 和 qiankun)

    初步认识微前端 微前端是什么 现在的前端应用,功能.交互日益复杂,若只由一个团队负责,随着时间的推进,会越来越庞大,愈发难以维护. 微前端这个名词,第一次提出是在2016年底.它将微服务(将单一应用程 ...

随机推荐

  1. Webpack 2 视频教程 017 - Webpack 2 中分离打包项目代码与组件代码

    原文发表于我的技术博客 这是我免费发布的高质量超清「Webpack 2 视频教程」. Webpack 作为目前前端开发必备的框架,Webpack 发布了 2.0 版本,此视频就是基于 2.0 的版本讲 ...

  2. 关于recycleview 滑动item变长(item变形)问题

    昨天在做项目的时候出现了bug,表现是在滑动的时候,整个item会被拉长了,松手后就回归正常大小了, 出现这个的主要原因是因为你的item布局中最大的那个根布局是 match_parent状态,因此导 ...

  3. ZJOI 2015 诸神眷顾的幻想乡

    题目描述 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看.幽香当然也非常 ...

  4. ADO.NET访问数据库

    1:ADO.NET数据库的方法和技术 2:ADO.NET的主要组成: 1>DataSet(数据集)-----独立于数据间的数据访问 2>.NETFramework(数据提供程序)----- ...

  5. ${param.name}和${name}的区别

    ${param.name} == request.getParam("name") ${name} == request.getAttribute("name" ...

  6. chrome console的使用 : 异常和错误的处理 – Break易站

    本文内容来自:chrome console的使用 : 异常和错误的处理 – Break易站 利用 Chrome DevTools 提供的工具,您可以修复引发异常的网页和在 JavaScript 中调试 ...

  7. php 抽象类abstract

    程序中,有些类的作用只是用来继承,无须实例化: 为了满足类的这种需求,php提供了抽象类的概念 ,关键词abstract: 抽象类原则: 抽象类不能被实例化 有抽象方法的类一定是抽象类:类必须要abs ...

  8. iOS SQLite解密之SQLCipher

    开门见山,本文主要讲在Mac下使用SQLCipher编译解密数据库文件方法,iOS项目集成SQLCipher自己可以百度,网上帖子很多. 官方集成文档:https://www.zetetic.net/ ...

  9. jdk8新特性(文章推荐)

    文章推荐 jdk9都已经出来了,虽然很多项目都已经使用jdk8,但是很少会用到jdk8中的新特性.本人经常用的到也就是使用Stream,Lambda,但也仅仅是使用,基本不知道什么Function,C ...

  10. Spark 学习笔记大纲

    Spark 内核 第28课:Spark天堂之门解密 (点击进入博客)从 SparkContext 创建3大核心对象开始到注册给 Master 这个过程中的源码鉴赏 第29课:Master HA彻底解密 ...