当前位置: 首页 > article >正文

uniapp开发常用辅助函数mapState、mapMutations和computed来映射vue属性和方法


1、如果要获取store里面的state的city属性。首先来看看没有使用mapState的情况      

  {{this.$store.state.city}}

再来看看使用mapState后   {{this.city}}

那么为什么会这样呢?先来看看官方的定义:

        当一个组件需要获取多个状态时候,将这些状态都声明为计算属性时,会有些重复和冗余。为了解决这个问题,我们可以使用 mapState 辅助函数帮助我们生成计算属性,让你少按几次键:

首先什么是状态?即state,state又是用来存储一些数据的,所以不难理解。

// store.js

/* vuex的核心管理对象模块:store  */
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)
// 状态对象
const state = { // 初始化状态 这里放置的状态可以被多个组件共享
  count: 1,
  name: 'daming'
}
const mutations = {}
const action = {}
const getters = {}

export default new Vuex.Store({
  state, // 状态
  mutations, // 包含多个更新state函数的对象
  actions, // 包含多个队形事件回调函数的对象
  getters // 包含多个getter计算属性函数的对象
})


2、代码中使用

import {mapState} from "vuex"
// 使用mapState, 此时,city已经被映射了,所以可以直接使用 this.city 去获取属性值
computed:{
    //意思是将vuex中的city数据映射到组件的computed属性里
    ...mapState(["city"])
}

1. html 中直接使用 city
2. js中使用 this.city


3.第三种使用方式

        还有一种使用方法,意思是将store里面的state里面的city属性映射到computed属性中的 currentCity 中。即 currentCity 代表了 $store.state.city  

​​computed:{ ...mapState({ currentCity:"city" }) }​​

1.使用 Vuex 并不意味着你需要将所有的状态放入 Vuex。虽然将所有的状态放到 Vuex 会使状态变化更显式和易调试,但也会使代码变得冗长和不直观。

2.如果有些状态严格属于单个组件,最好还是作为组件的局部状态。你应该根据你的应用开发需要进行权衡和确定。

3.由于 Vuex 的状态存储是响应式的,所以可以使用计算属性来获得某个状态

4.当状态改变时,都会重新求取计算属性,并且触发更新相关联的 DOM

5.通过下面的计算属性,就可以在当前组件中访问到count,name,nameAlias等了 在模板中我们通过大括号符号打印出来。 


 

4.在组件中提交 Mutation
你可以在组件中使用 this.$store.commit(‘xxx’) 提交 mutation,或者使用 mapMutations 辅助函数将组件中的 methods 映射为 store.commit 调用(需要在根节点注入 store)。

import { mapMutations } from 'vuex'

export default {
  // ...
  methods: {
    ...mapMutations([
      'increment', // 将 `this.increment()` 映射为 `this.$store.commit('increment')`

      // `mapMutations` 也支持载荷:
      'incrementBy' // 将 `this.incrementBy(amount)` 映射为 `this.$store.commit('incrementBy', amount)`
    ]),
    ...mapMutations({
      add: 'increment' // 将 `this.add()` 映射为 `this.$store.commit('increment')`
    })
  }
} 



若是按照模块来写的,只需在前面加上模块的名字,如上中的第三个:

   ...mapMutations("moudleA"{
      add: 'increment' // 将 `this.add()` 映射为 `this.$store.commit('/moudleA/increment')`
    })

 


http://www.kler.cn/a/272650.html

相关文章:

  • C语言编程笔记:文件处理的艺术
  • 力扣解题汇总(简单)_JAVA
  • Web端实时播放RTSP视频流(监控)
  • opencv3.4 ffmpeg3.4 arm-linux 交叉编译
  • 放大芯片参数阅读
  • HarmonyOS NEXT应用开发边学边玩系列:从零实现一影视APP (三、影视搜索页功能实现)
  • 一些 AI 工具
  • Redis基本使用
  • 算法D48 | 动态规划10 | 121. 买卖股票的最佳时机 122.买卖股票的最佳时机II
  • ThreadX(RTOS)在Ubuntu编译,并执行案例
  • 实时表支持自定义打印,适配又便捷
  • WEB前端 HTML 列表表格
  • SRC实战 | 信息泄露挖掘
  • 坐席助手:提升服务体验
  • Qt实现简单的五子棋程序
  • C++不定参数模板、折叠表达式和类型推导
  • 代码训练LeetCode(11)删除有序数组中的重复项II
  • 新一代云原生数据库OLAP
  • python知识点总结(三)
  • Python实战:Flask轻量级web框架入门
  • B007-springcloud alibaba 消息驱动 Rocketmq
  • 数据结构的美之链表和树
  • 浅谈嵌入式软件测试秘诀
  • 使用tui-image-editor 图片编辑 标注图片
  • 把软件加入开机自启动
  • 鸿蒙Socket通信示例(TCP通信)