在上篇中,我们可以知道如果想要访问vuex.store中state中的数据,需要this.$store.state.属性名。显然这样访问数据写的代码很很不简洁的,辅助函数就是用来解决这个问题的。

1、辅助函数:

  通过辅助函数mapState、mapActions、mapMutations,把vuex.store中的属性映射到vue实例身上,这样在vue实例中就能访问vuex.store中的属性了,对于操作vuex.store就很方便了。

  state辅助函数为mapState,actions辅助函数为mapActions,mutations辅助函数为mapMutations。(Vuex实例身上有mapState、mapActions、mapMutations属性,属性值都是函数)

2、如何使用辅助函数

   在当前组件中引入Vuex

   通过Vuex来调用辅助函数

3、辅助函数如何去映射vuex.store中的属性

  1、mapState:把state属性映射到computed身上

computed:{
...Vuex.mapState({
input:state=>state.inputVal,
n:state=>state.n
})
}
属性1:state:
用来存储公共的状态 在state中的数据都是响应式的。
响应式原因:state里面有一个getters、setters方法;data中的数据也是响应式的,因为里面也有getters和setters方法 辅助函数
mapState 1、在computed属性中来接收state中的数据 接收方式有2种(数组和对象,推荐对象) computed:Vuex.mapState(["属性"]) 把state中的数据通过mapState映射到computed组件身上 computed:Vuex.mapState({
key:state=>state.属性 //优点:01本身key值是别名,要的是val的值,key的值a 和 val="a"一样就行,随意写。
减少state里面长的属性名。 02可以在函数内部查看state中的数据
数组方式的话,必须按照state中的属性名
}) 2、如果自身组件也需要使用computed的话,通过解构赋值去解构出来 computed:{
...Vuex.mapState({
key:state=>state.属性
})
}
   2、mapAcions:把actions里面的方法映射到methods中
  

methods:{
...Vuex.mapActions({
add:"handleTodoAdd", //val为actions里面的方法名称
change:"handleInput"
})
}
//直接代用add和change方法就行,不过要记得在actions里面做完数据业务逻辑的操作
之前我们还需要这样写一大串函数调用,
// methods: {
// handleInput(e){           
// let val = e.target.value;
// this.$store.dispatch("handleInput",val )
// },
// handleAdd(){
// this.$store.dispatch("handleTodoAdd")
// }
// }
 
属性2:actions:
actions里面的函数主要用来处理异步的函数以及一些业务逻辑,每一个函数里面都有一个形参 这个形参是一个对象
里面有一个commit方法,这个方法用来触发mutations里面的方法 辅助函数
mapActions 使用方式
methods:Vuex.mapActions([""]) methods:{
...Vuex.mapActions({
key:val--->actions里面的方法名称
}) }

  3、mapMutations:把mutations里面的方法映射到methods中

    只是做简单的数据修改(例如n++),它没有涉及到数据的处理,没有用到业务逻辑或者异步函数,可以直接调用mutations里的方法修改数据。

methods:{

        ...Vuex.mapMutations({
handleAdd:"handlMutationseAdd"
})
}
属性3:mutations:
mutations里面的函数主要用来修改state中的数据。mutations里面的所以方法都会有2个参数 一个是store中的state
另外一个是需要传递的参数 辅助函数
mapMutations
使用方式
methods:Vuex.mapMutations([""]) methods:{
...Vuex.mapMutations({
key:val--->actions里面的方法名称
}) }

理解state、actions、mutations,可以参考MVC框架。state可以比喻成一个数据库,知识它是响应式的,刷新页面数据就会改变;actions比喻成controller层,做数据的业务逻辑;mutations比喻成model层,做数据的增删改查操作。

   4、mapGetters:把getters属性映射到computed身上

 

 computed:{
...Vuex.mapGetters({
NumN:"NumN"
}) }
属性4:getters:计算属性
getters类似于组件里面computed同时也是监听属性的变化,当state中的属性发生改变的时候就会
触发getters里面的方法。getters里面的每一个方法中都会有一个参数 state 使用方式
this.$store.getters.方法名称 辅助函数 mapGetters mapgetters使用在组件的computed中 1、
Vuex.mapGetters(["方法名称"])
Vuex.mapGetters({
key:val--》val就是getters中的函数名称
})
  5、modules属性:  模块 (和辅助函数没关系了)
    把公共的状态按照模块进行划分
    1、每个模块都相当于一个小型的Vuex
    2、每个模块里面都会有state getters actions mutations
    3、切记在导出模块的时候 加一个 namespaced:true 主要的作用是将每个模块都有独立命名空间
4、namespace:true
  在多人协作开发的时候,由于个人单词量有限,可能子模块和主模块中的函数名字会相同,这样嗲用函数的时候,相同名字的函数都会被调用,就会发生问题。
  为了解决这个问题,上面提到了导出模块的时候要加namespace:true.
  那么怎么调用子模块中的函数呢?假如我的子模块名字为todo.js。  函数名字就改成todo/函数名字。
 
  为什么这样写调用,输出模块后的store实例
  也可以看到模块化后,store实例的state属性的访问改变了,this.$store.state.todo.inputVal
 
可以简单总结一下辅助函数通过vuex使用,比喻成映射关系为: mapState/mapGettes--->computed  ;  mapAcions/mapMutations---->methods   

vuex辅助函数和vuex5个属性的更多相关文章

  1. Vuex的五个核心属性

    Vuex的五个核心属性 Vuex的五个核心概念 本文参考自Vue文档,说的非常详细,建议看文档. Vuex是什么? VueX 是一个专门为 Vue.js 应用设计的状态管理架构,统一管理和维护各个vu ...

  2. vuex - 辅助函数学习

    官网文档: https://vuex.vuejs.org/zh-cn/api.html  最底部 mapState 此函数返回一个对象,生成计算属性 - 当一个组件需要获取多个状态时候,将这些状态都声 ...

  3. Vuex之store仓库计算属性Getter

    (1)简介 Getter相当于vue中的computed计算属性,getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算,这里可以通过定义vuex的Getter来获 ...

  4. vuex的mapState方法来获取vuex的state对象中属性

    有两种写法 1.首先在组件中引入vuex的mapState方法: 首先在组件中引入vuex的mapState方法: import { mapState } from 'vuex' 然后在compute ...

  5. vuex有哪几种属性

    有五种,分别是 State. Getter.Mutation .Action. Modulestate => 基本数据(数据源存放地)getters => 从基本数据派生出来的数据muta ...

  6. Vue面试题2

    Class与Style绑定工作有用过吗: 有,后台管理系统菜单.主题色切换 .tab选项卡等..... 计算属性和侦听器区别.使用场景: 计算属性有缓存.并且是响应式依赖缓存,调用不加小括号 利用vu ...

  7. 理解Vuex的辅助函数mapState, mapActions, mapMutations用法

    在讲解这些属性之前,假如我们项目的目录的结构如下: ### 目录结构如下: demo1 # 工程名 | |--- dist # 打包后生成的目录文件 | |--- node_modules # 所有的 ...

  8. [转]理解Vuex的辅助函数mapState, mapActions, mapMutations用法

    原文地址:https://www.cnblogs.com/tugenhua0707/p/9794423.html 在讲解这些属性之前,假如我们项目的目录的结构如下: ### 目录结构如下: demo1 ...

  9. vue-learning:41 - Vuex - 第二篇:const store = new Vue.Store(option)中option选项、store实例对象的属性和方法

    vuex 第二篇:const store = new Vue.Store(option)中option选项.store实例对象的属性和方法 import Vuex from 'vuex' const ...

随机推荐

  1. CUDA开发指南

    安装指南:https://blog.csdn.net/qilixuening/article/details/77503631 安装了anaconda不需要安装cuda和cudnn?:https:// ...

  2. Spring Boot教程(一)在springboot中用redis实现消息队列

    环境依赖 创建一个新的springboot工程,在其pom文件,加入spring-boot-starter-data-redis依赖: <dependency> <groupId&g ...

  3. 3-Gitblit服务器搭建及IDEA整合Git使用

    背景:虽然有GitHub.GitLab这样强大的Git仓库,但是涉及私有Git库要收费,所以自己动手搭建免费的用用 环境:windows 7 旗舰版.JDK 1.8.IDEA 2017 ------- ...

  4. navicat_premium_x64最新版安装说明

    先到官网下载最新的navicat http://www.navicat.com.cn/ 下载破解文件 链接: https://pan.baidu.com/s/1hhsh5Tfe4c_lQeyX8D-C ...

  5. Vue.js之Ajax请求

    Vue.js同React.Angular,可以说号称前端三巨头. 前段时间,有个哥们说,Vue.js现在出2.0版本了.可是我现在还是在用1.0的. Vue.js一直都没有好好系统的学习,包括目前公司 ...

  6. leetcode-easy-array-283 move zeros

    mycode  77.24% class Solution(object): def moveZeroes(self, nums): """ :type nums: Li ...

  7. SQLAlcvchem

    一.安装(稳定版的1.2.17) 二.一般使用(切记切记不要使用模块的名字作为项目名字,否则会出现玄学解决不了的问题------坑) #.导入SQLALchemy from sqlalchemy.ex ...

  8. 【原创实现】C 多线程入门Demo CAS Block 2种模式实现

    分Cas和Block模式实现了demo, 供入门学习使用,代码全部是远程实现. 直接上代码: /* ================================================== ...

  9. FreeBSD上安装Cassandra 3.10

    哈哈,你居然点进来了,来吧,一起吐槽FreeBSD啊,装了一上午Cassandra 3.10都没有装成功, 终于,鄙人一条 shutdown -p now 结束了FreeBSD,默默打开了CentOS ...

  10. 让DOM元素自动滚到视野内ScrollIntoView

    概述 项目中需要把一个DOM元素自动滚动到视野内,百思不得其解,最后再element库里面发现了这个方法,记录下来供以后开发时参考,相信对其他人也有用. 参考资料:element scroll-int ...