首页 > 其他分享 >Vue进阶(幺肆捌):Vuex 辅助函数详解

Vue进阶(幺肆捌):Vuex 辅助函数详解

时间:2023-08-11 11:01:51浏览次数:46  
标签:computed Vue 进阶 state 属性 Vuex store 函数

(文章目录)

一、前言

一般情况下,如果需要访问vuex.storestate存放的数据,需要使用this.$store.state.属性名方式。显然,采取这样的数据访问方式,代码略显繁杂,辅助函数为了解决繁杂行问题应运而生。

二、辅助函数

通过辅助函数mapGettersmapStatemapActionsmapMutations,把vuex.store中的属性映射到vue实例身上,这样在vue实例中就能访问vuex.store中的属性了,对于操作vuex.store就变得非常方便。

state辅助函数为mapStateactions辅助函数为mapActionsmutations辅助函数为mapMutations。(Vuex实例身上有mapStatemapActionsmapMutations属性,属性值都是函数)

三、如何使用辅助函数

  1. 需要在当前组件中引入Vuex

  2. 通过Vuex来调用辅助函数。

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

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

computed:{
   ...Vuex.mapState({
      input:state=>state.inputVal,
      n:state=>state.n
  })   
}

简写形式如下:

import { mapGetters } from 'vuex'
computed:{
	...mapGetters(['input', 'n'])
}

state:用来存储公共状态, state中存储的数据都是响应式的。

响应式原因:state里面有getterssetters方法;data中的数据也是响应式的,因为里面也有getterssetters方法。

computed属性中来接收state中的数据,接收方式有2种(数组和对象,推荐对象).

优点:

  • 本身key值是别名,要的是val值,key的值a 和 val="a"一样就行,随意写。减少state里面长的属性名。
  • 可以在函数内部查看state中的数据,数组方式的话,必须按照state中的属性名。
  computed:Vuex.mapState({
    key:state=>state.属性
  })

如果自身组件也需要使用computed的话,通过解构赋值去解构出来。

  computed:{
    ...Vuex.mapState({
       key:state=>state.属性
    })
  }

4.2 mapAcions:把 actions 方法映射到 methods 中

methods:{
    ...Vuex.mapActions({
        add:"handleTodoAdd",    //val为actions里面的方法名称
        change:"handleInput"     
    })
}

简写形式如下:

import { mapActions } from 'vuex'
methods:{  
	...mapActions(['add', 'change'])
}

add、change为action方法别名,直接代用add和change方法就行,不过要记得在actions里面做完数据业务逻辑的操作。

等价于如下的函数调用,

methods: {
	handleInput(e){           
		let val = e.target.value;
		this.$store.dispatch("handleInput",val )
	},
	handleAdd(){
		this.$store.dispatch("handleTodoAdd")
	}
}

actions里面的函数主要用来处理异步操作以及一些业务逻辑,每一个函数里面都有一个形参,这个形参是一个对象,里面有一个commit方法,这个方法用来触发mutations里面的方法。

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

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

methods:{
    ...Vuex.mapMutations({
        handleAdd:"handlMutationseAdd"
    })
}

简写形式如下:

import { mapMutations} from 'vuex'
methods:{  
	...mapMutations(['handleAdd'])
}

mutations里面的函数主要用来修改state中的数据。mutations里面的所有方法都会有2个参数,一个是store中的state,另外一个是需要传递的参数。

理解stateactionsmutations,可以参考MVC框架。

  • state看成一个数据库,只是它是响应式的,刷新页面数据就会改变;
  • actions看成controller层,做数据的业务逻辑;
  • mutations看成model层,做数据的增删改查操作。

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

computed:{
    ...Vuex.mapGetters({
        NumN:"NumN"
    })
}

简写形式如下:

import { mapGetters} from 'vuex'
methods:{  
	...mapGetters(['NumN'])
}

getters类似于组件里面computed,同时也监听属性的变化,当state中的属性发生改变的时候就会触发getters里面的方法。getters里面的每一个方法中都会有一个参数 state

4.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

五、命名空间

模块开启命名空间后,享有独自的命名空间。示例代码如下:

export default {
	namespaced: true,
	....
}

mapStatemapGettersmapMutationsmapActions第一个参数是字符串(命名空间名称),第二个参数是数组(不需要重命名)/对象(需要重命名)。

mapXXXs('命名空间名称',['属性名1','属性名2'])

mapXXXs('命名空间名称',{

  '组件中的新名称1':'Vuex中的原名称1',

  '组件中的新名称2':'Vuex中的原名称2',

})

六、拓展阅读

标签:computed,Vue,进阶,state,属性,Vuex,store,函数
From: https://blog.51cto.com/shq5785/7044533

相关文章

  • 《VTK图形图像开发进阶》第3章VTK基本数据结构——属性数据
    属性数据(AttributeData)是与数据集组织结构相关联的信息。3.1标量数据#include<vtkAutoInit.h>VTK_MODULE_INIT(vtkRenderingOpenGL2);VTK_MODULE_INIT(vtkRenderingFreeType);VTK_MODULE_INIT(vtkInteractionStyle);#include<vtkSmartPointer.h>#include<vtkPoint......
  • vue 实现动态表单点击新增 增加一行输入框
    点击增加后会新增一行,点击每行后面的删除图标则会删除该行,新增按钮只会出现在最后一行<el-col:span="12"class="mb20"> <el-form-item :label="index==0?'选择原材料':''" v-for="(item,index)inform.productItemList"......
  • 高等代数学习的提高与进阶
    高中数学的学习与大学数学的学习有何不同?这个问题涉及到高中数学与大学数学之间的衔接,对于数学学院大一新生尽快转变思维方式,顺利进入数学专业基础课(数学分析、高等代数和空间解析几何)的学习尤为重要。以高等代数课程为例,通常每周会安排4学时的正课以及2学时的习题课。在正课上,任......
  • 模拟Vue2的v-model
    模拟Vue2的v-model<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>Title</title></head><body><div><!--<buttonid="myBtn">改变user......
  • uniapp Vue2升级Vue3使用Vite分包
    uniappVue2使用webpack打包配置根目录下创建vue.config.js文件constpath=require('path')constCopyWebpackPlugin=require('copy-webpack-plugin')//最新版本copy-webpack-plugin插件暂不兼容,推荐v5.0.0letfilePath=''letTimestamp=''//......
  • vue3+vite+view-ui-plus 实现按需引用
    现有项目使用的是vue3+vite+view-ui-plus由于公司要求秒开速度对h5页面进行优化,首先想到的是把组件的引用从全量引用打包改成按需引用;下面是改之前的 view-ui-plus引用配置,简单粗暴直接在main.ts中引用  importViewUIPlusfrom'view-ui-plus'import'view-ui-plus/d......
  • 《VTK图形图像开发进阶》第3章VTK基本数据结构——单元类型
    数据集由一个或多个单元组成。一系列有序的点按指定类型连接所定义的结构就是单元(Cell),单元是VTK可视化系统的基础。这些顺序连接的点定义了单元的拓扑结构,而点的坐标定义了单元的几何结构。如下图是类型为六面体(Hexahedron)的单元,顶点列表(由点的索引号表示,即8-10-1-6-21-22-5......
  • vue的响应式
    letperson={name:'路飞',age:18}//letp={}//Object.defineProperty(p,"name",{//get(){//有人读取name时调用//returnperson.name;//},//set(value){//有人修改name时调用//console.log("有人修改了name属性"......
  • avue组件自定义按钮/标题/内容/搜索栏
    话不多说笔记直接分享!!一、自定义crud搜索栏组件<templateslot-scope="scope"slot="provinceCodeSearch"> <avue-select v-model="objFrom.provinceCode"//这是存放省份的code placeholder="请选择省市" :di......
  • VUE+ElementUI的表单验证二选一必填项,并且满足条件后清除表单验证提示
    上代码<el-form-itemlabel="出库单号"prop="ecode"ref="ecode":rules="rules.ecode"><el-inputv-model="queryParams.ecode"placeholder="出库单号和出库箱号至少填写一项"clearable......