1. Vuex核心概念主要如下

  • state : 存储共享数据
  • mutation: 变更store中的数据,方法,不能异步操作
  • action: 异步操作,通过触发mutation变更数据
  • getter: 对Store中数据重新加工,但是不改变原来的数据

2. State

  1. 概念

  提供唯一公共数据源的地方,所有共享数据都要统一放到Store中的state中进行存储

  2. step

  1. 创建3个组件 新增Add.vue, 减法Sub.vue, 主要组件Main.vue

  Add.vue

<template>
<div>
<h3>这是Add组件:</h3>
<button>+1</button>
</div>
</template> <script>
export default { }
</script>

  Sub.vue

<template>
<div>
<h3>这是Sub组件:</h3>
<button>-1</button>
</div>
</template> <script>
export default { }
</script>

 Main.vue 先导入Add.vue Sub.vue, 然后注册对应的组件(路由注册省略)

<template>
<div>
<my-add></my-add>
<my-sub></my-sub>
</div>
</template> <script>
// 导入
import Add from './Add.vue'
import Sub from './Sub.vue' export default {
data() {
return {}
},
// 注册
components: {
'my-add': Add,
'my-sub': Sub
}
}
</script>

  2. 访问http://127.0.0.1:8080/#/main

  3. 这时候我们想Add.vue Sub.vue想访问同样的数据如何操作呢

   4. store.js -> state 创建共享数据

export default new Vuex.Store({
state: {
count:0
},
mutations: { },
actions: { }
})

  5.访问共享数据方式一: 通过this.$store.state.全局数据名

  6. Add.vue ->

<template>
<div>
<h3>这是Add组件:{{this.$store.state.count}}</h3>
<button>+1</button>
</div>
</template> <script>
export default { }
</script>

  7.效果显示

  

  8. 访问共享数据方式二: 通过mapState函数访问全局数据 ->Sub.vue

<template>
<div>
<h3>这是Sub组件:{{count}}</h3>
<button>-1</button>
</div>
</template> <script>
// 导入mapState函数
import {mapState} from 'vuex'
export default {
data() {
return {}
},
// 定义计算属性,把全局变量映射到当前组件中的computed计算属性中
computed: {
...mapState(['count']),
}
}
</script>

  9. 效果

3. matation

  1. 概念

  用于变更state中的数据

  2. 定义mutation

  1. store.js -> 在mutations中定义一个加法操作.并且传递state的参数

export default new Vuex.Store({
state: {
count:0
},
mutations: {
// 定义一个加法操作
add(state) {
// 变更state
state.count ++
}
},
actions: { }
})

  3. 触发mutation

  1. 触发mutation 方式一  -> Add.vue  -> 通过this.$store.commit('方法名')

<template>
<div>
<h3>这是Add组件:{{this.$store.state.count}}</h3>
<button @click="Add">+1</button>
</div>
</template> <script>
export default {
methods: {
// 绑定click事件
Add() {
// 触发mutations
this.$store.commit("add");
}
}
};
</script>

  2. 触发方式二:导入mapMutations函数,映射到methods

store.js

export default new Vuex.Store({
state: {
count:0
},
mutations: {
// 定义一个加法操作
add(state) {
// 变更state
state.count ++
},
sub(state) {
// 变更减法
state.count --
}
},
actions: { }
})

Sub.vue -> click事件可以直接调用sub方法

<template>
<div>
<h3>这是Sub组件:{{count}}</h3>
<button @click="sub">-1</button>
</div>
</template> <script>
// 导入mapState函数
// 导入 mapMutations函数
import { mapState, mapMutations } from "vuex";
export default {
data() {
return {};
},
// 定义计算属性,把全局变量映射到当前组件中的computed计算属性中
computed: {
...mapState(["count"])
},
// 映射到methods
methods: {
...mapMutations(['sub'])
}
};
</script>

  

4. Action

  1. 概念

  处理异步操作,操作步骤不能在mutation中操作,只能通过Action触发mutation方式变更数据

  2. 创建异步操作

  store.js

export default new Vuex.Store({
state: {
count: 0
},
mutations: {
// 定义一个加法操作
add(state) {
// 变更state
state.count++
},
sub(state) {
// 变更减法
state.count--
}
},
actions: {
// 创建异步操作,每1秒后条用mutation中的add
addAsync(context) {
setTimeout(() => {
context.commit('add')
}, 1000)
}
}
})

  3. 触发action 中的第一种方式: this.$store.dispath()

  Add.vue

<template>
<div>
<h3>这是Add组件:{{this.$store.state.count}}</h3>
<button @click="Add">+1</button>
<button @click="AddAsync">+1</button>
</div>
</template> <script>
export default {
methods: {
// 触发mutations
Add() {
this.$store.commit("add");
},
// 触发action
AddAsync() {
this.$store.dispatch("addAsync");
}
}
};
</script>

  4. 触发action的第二种方式:mapActions

store.js

export default new Vuex.Store({
state: {
count: 0
},
mutations: {
// 定义一个加法操作
add(state) {
// 变更state
state.count++
},
sub(state) {
// 变更减法
state.count--
}
},
actions: {
// 创建异步操作,每1秒后条用mutation中的add
addAsync(context) {
setTimeout(() => {
context.commit('add')
}, 1000)
},
subAsync(context) {
setTimeout(() => {
context.commit('sub')
}, 1000)
}
}
})

 Sub.vue  -> 导入mapActions函数,映射到methods方法中

<template>
<div>
<h3>这是Sub组件:{{count}}</h3>
<button @click="sub">-1</button>
<button @click="subAsync">异步-1</button>
</div>
</template> <script>
// 导入mapState函数
// 导入 mapMutations函数
import { mapState, mapMutations, mapActions } from "vuex";
export default {
data() {
return {};
},
// 定义计算属性,把全局变量映射到当前组件中的computed计算属性中
computed: {
...mapState(["count"])
},
// 映射到methods
methods: {
...mapMutations(["sub"]),
...mapActions(["subAsync"])
}
};
</script>

 

5. getter

  1. 概念

  用于对Store中的数据进行重新包装成新的数据(以前的数据不变化),Store中的数据变更,Getter中的数据也变更

  2.定义Getter

  store.js

getters: {
// 定义一个showNum 参数参入state
showNum(state){
return '当前getter数据为' + state.count
}
}

  3.获取getter中数据方式一: this.$store.getters.名称 -> Add.vue

<template>
<div>
<h3>这是Add组件:{{this.$store.state.count}}</h3>
<h3>getter:{{this.$store.getters.showNum}}</h3>
<button @click="Add">+1</button>
<button @click="AddAsync">+1</button>
</div>
</template>

  4. 获取getter数据方式二:mapGetters 映射到methods -> Sub.vue

<template>
<div>
<h3>这是Sub组件:{{count}}</h3>
<h3>这是Sub组件getter:{{showNum()}}</h3>
<button @click="sub">-1</button>
<button @click="subAsync">异步-1</button>
</div>
</template> <script>
// 导入mapState函数
// 导入 mapMutations函数
// 导入mapGetters 函数
import { mapState, mapMutations, mapActions, mapGetters } from "vuex";
export default {
data() {
return {};
},
// 定义计算属性,把全局变量映射到当前组件中的computed计算属性中
computed: {
...mapState(["count"])
},
// 映射到methods
methods: {
...mapMutations(["sub"]),
...mapActions(["subAsync"]),
...mapGetters(['showNum'])
}
};
</script>

  

演示效果

github demo: https://github.com/wangxiao9/vue_coding.git

【VUE】8.VUEX核心概念的更多相关文章

  1. 极客时间_Vue开发实战_05.Vue组件的核心概念(1):属性

    05.Vue组件的核心概念(1):属性 代码地址: https://github.com/tangjinzhou/geektime-vue-1/blob/master/%E6%BC%94%E7%A4% ...

  2. 极客时间_Vue开发实战_06.Vue组件的核心概念(2):事件

    06.Vue组件的核心概念(2):事件 通过emit传递给父组件 我们点击了重置失败,上层的div的click=handleDivClick是接收不到.重置失败的点击的行为的 通常情况下,你不用.st ...

  3. 极客时间_Vue开发实战_07.Vue组件的核心概念(3):插槽

    07.Vue组件的核心概念(3):插槽 严格来的说在2.0之后已经不分区这两种插槽的概念了. 因为它底层的实现已经趋向于相同了. 2.6为了兼容2.5的版本,现在依然可以用这两种写法 作用域插槽就是多 ...

  4. 2.基础:Vue组件的核心概念

    一.组件基础和注册 组件概念 组件系统是 Vue 的另一个重要概念,他的核心就是封装和复用. 细节 组件的name必须是全局唯一. 二.属性.事件和插槽 组件的三大核心概念:属性.事件和插槽. 属性, ...

  5. Vue学习笔记:Vue组件的核心概念(下)

    1.双向绑定和单向数据流: 本质上还是单向数据流 视图<——>数据 v-model:仅仅是一个简写,用更少代码去实现功能. 自定义事件 .sync 修饰符 2.虚拟DOM及KEY属性作用 ...

  6. 深入理解Vue组件3大核心概念

    摘要: 搞懂Vue组件! 作者:浪里行舟 原文:详解vue组件三大核心概念 Fundebug经授权转载,版权归原作者所有. 前言 本文主要介绍属性.事件和插槽这三个vue基础概念.使用方法及其容易被忽 ...

  7. vue使用--vuex快速学习与使用

    什么是vuex? Vuex核心概念 Vuex安装与使用 1.安装 2.目录结构与vuex引入 3.store中变量的定义.管理.派生(getter) 4.vuex辅助函数的使用说明 Vuex刷新数据丢 ...

  8. vue项目--vuex状态管理器

    本文取之官网和其他文章结合自己的理解用简单化的语言表达.用于自己的笔记记录,也希望能帮到其他小伙伴理解,学习更多的前端知识. Vuex 是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态 ...

  9. vue(23)Vuex的5个核心概念

    Vuex的核心概念 Vuex有5个核心概念,分别是State,Getters,mutations,Actions,Modules. State   Vuex使用单一状态树,也就是说,用一个对象包含了所 ...

随机推荐

  1. Parquet 源码解析

    date: 2020-07-20 16:15:00 updated: 2020-07-27 13:40:00 Parquet 源码解析 Parquet文件是以二进制方式存储的,所以是不可以直接读取的, ...

  2. 手把手教你搭建SVN服务

    参考一下地址 https://blog.csdn.net/marstonyjiang/article/details/52033916

  3. Java数据结构-00导论

    一个程序是怎样组成的呢?数据结构+算法=程序 一.什么是数据结构: 简单定义就是研究数据的存储方式:选择适当的数据结构可以提高计算机程序的运行效率(时间复杂度O)和存储效率(空间复杂度S). 二.数据 ...

  4. Redis 数据结构与编码技术 (Object Encoding)

    数据结构实现 相信大家对 redis 的数据结构都比较熟悉: string:字符串(可以表示字符串.整数.位图) list:列表(可以表示线性表.栈.双端队列.阻塞队列) hash:哈希表 set:集 ...

  5. audioread.NoBackendError

    audioread.NoBackendError 起因 使用以下代码读取音频文件时: # !/usr/bin/python # -*- coding: utf-8 -*- ""&q ...

  6. linux的mysql修改默认端口3306

    linux 修改mysql默认端口3306 cd /etc/mysql/my.cnf 修改两处 客户端的port=3306 和mysqld的服务器端口port=3306 [client] port=3 ...

  7. 834. Sum of Distances in Tree —— weekly contest 84

    Sum of Distances in Tree An undirected, connected tree with N nodes labelled 0...N-1 and N-1 edges a ...

  8. .netcore中的依赖注入

    IOC.DI相关概念的理解 1.依赖:简单的讲就是"引用到".例如AccountController.cs引用到IAccountService.cs,那么AccountContro ...

  9. RabbitMq 基本命令

    rabbitmqadmin 命令汇总: 命令 解释 rabbitmqadmin list users 查看所有用户 User rabbitmqadmin list users name 查看所有用户名 ...

  10. CF1008D Pave the Parallelepiped

    容斥原理 解法一: 其他容斥原理的题也可以用这种思想 先把$A$,$B$,$C$分解因数 一种很暴力的想法是,将这些因数分成若干个集合(画出韦恩图),然后对有序数组的三个数分别枚举其位于哪一个集合中 ...