Vuex 同步函数 异步函数 getters

本文介绍了Vuex中同步函数、异步函数以及getters的使用方法,通过示例代码展示了如何在store.js和App.vue中应用,并讨论了mapState、mapGetters、mapMutations和mapActions的实践技巧,帮助理解它们在状态管理中的作用。
摘要由CSDN通过智能技术生成

store.js:

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
  	personList:[
    {
      name:'锦觅',
      sex:'女'
    },
    {
      name:'旭凤',
      sex:'男'
    },
    {
      name:'鎏英',
      sex:'女'
    }
    ]
  },
  getters:{
      girlNum(state){
        return state.personList.filter(item=>item.sex=='女').length
      }
  },
  mutations: {	//放同步函数的地儿
  	add(state,person){
      state.personList.push(person)
    }
  },
  actions: {	//放异步函数的地儿
   add2s(context,person){
     setTimeout(item=>{
       context.commit('add',person)
     },2000)
   }
  }
})

App.vue:

<template>
  <div id="app">
    <h1>App标题</h1>
    <div>姓名:<input type="text" v-model='name'></div>
    <div>性别:<input
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vuex辅助函数是一组为了简化在Vue组件中访问和使用store中的state、getter、mutation和action的工具函数。使用辅助函数可以减少代码量并提高代码的可读性。其中常用的辅助函数包括mapState、mapGetters、mapMutations和mapActions。 mapState函数可以帮助我们将store中的state映射到组件的计算属性中,使得我们可以直接在组件中访问state的值而不需要通过this.$store.state.xx来获取。这样可以简化代码,并且使得组件与store的关系更加清晰。 mapGetters函数可以帮助我们将store中的getter映射到组件的计算属性中。getter可以理解为store中的派生状态,通过对state的计算而得到的值。使用mapGetters可以让我们在组件中直接访问这些派生状态的值,而不需要通过this.$store.getters.xx来获取。 mapMutations函数可以帮助我们将store中的mutation映射到组件的方法中。mutation是修改store中state的唯一途径,通过提交mutation可以保证所有对state的修改都是同步的。使用mapMutations可以让我们在组件中直接调用mutation的方法,而不需要通过this.$store.commit('mutation名')来提交mutation。 mapActions函数可以帮助我们将store中的action映射到组件的方法中。action可以包含任意异步操作,并通过提交mutation来修改state。使用mapActions可以让我们在组件中直接调用action的方法,而不需要通过this.$store.dispatch('action名')来派发action。 总的来说,vuex辅助函数的作用是简化在Vue组件中访问和使用store中的状态、派生状态、修改状态和派发异步操作的代码,提高代码的可读性和可维护性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Vue全家桶学习—Vuex的4个辅助函数](https://blog.csdn.net/ZHANGYANG_1109/article/details/122050052)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题](https://download.csdn.net/download/weixin_38680671/13607816)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [vuex及其辅助函数](https://blog.csdn.net/qq_45718618/article/details/130002839)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值