首页 > 其他分享 >vuex详解

vuex详解

时间:2023-01-17 23:57:14浏览次数:42  
标签:actions state 详解 datas 复制 vuex store

vuex的介绍

vuexvue.js应用程序中的状态管理模式,它是集中式存储管理所有组件的数据状态,vuex解决了多个视图之间的数据交互同步,不需要进行组件连接再传递数据。

vuex的5大模块

state:用于数据的存储,是store中的唯一数据源

const state = {
  // 初始化两个组件的数据源,用于操作
  A: '',
  B: ''
}复制代码

getters:是一种计算属性,对state数据进行操作,常用于数据的筛选和多个数据的相关性计算

//定义
getters: {
    filteredList: state => {
      return state.list.filter(item => item > 5)
    }
}
//调用
this.$store.getters.filteredList;复制代码

mutations:是一种函数集合的对象,用于在里面改变state数据,但不能用于处理异步事件

const mutations = {
  receiveA(state, datas) {
    // 接收A的数据存放于state
    state.A = datas.A
  },
  receiveB(state, datas) {
    // 接收B的数据存放于state
    state.B = datas.B
  }
}
//调用mutations的方法,用commit触发
this.$store.commit('receiveA', {
  A: '我是A'
})复制代码

actions:类似于mutation,用于提交mutation来改变状态,而不直接变更状态,可以包含任意异步操作

const actions = {
    setNum(content){ //复制的一份store
      return new Promise((resolve)=>{//异步操作
        setTimeout(()=>{
          console.log('改变状态')
          resolve()
       },1000)
     })
   }
}
//调用actions,用dispatch触发
this.$store.dispatch('setNum')
//actions使用dispatch进行触发,就像mutation使用commit触发一样复制代码

modules:vuex中的命名空间,便于维护项目中将各个模块的状态分开定义和操作

vuex示例代码:

const store = new Vuex.Store({
  state:{
      // 初始化两个组件的数据源,用于操作
      A: '',
      B: ''
  },
  getters: {
    filteredList: state => {
      return state.list.filter(item => item > 5)//过滤小于5的值
    }
  },
  mutations:{
      receiveA(state, datas) {
          // 接收A的数据存放于state
          state.A = datas.A
      },
      receiveB(state, datas) {
         // 接收B的数据存放于state
         state.B = datas.B
      }
  },
  actions:{
    setNum(content){ //复制的一份store
      return new Promise((resolve)=>{//异步操作
        setTimeout(()=>{
          console.log('进行改变状态操作')
          resolve()
       },1000)
     })
   }
  }
})复制代码

vuex运用场景

  1. 页面与页面之间产生各种公共变量。

  2. 页面头部组件下,购物数量显示。

  3. 全局变量也可以用vuex来存储。

标签:actions,state,详解,datas,复制,vuex,store
From: https://www.cnblogs.com/beichengshiqiao/p/17058952.html

相关文章

  • 事件详解
    事件概念  事件的本质其实也是委托,只不过加了event关键字语法:publicevent委托名事件名注意:  定义事件时,一般要有一个委托类型,用这个委托类型来定义处理事件......
  • 初步理解:jvm运行机制,java程序运行机制,堆栈详解,jvm调优的目的。
    谷咕咕最近在准备面试,本来想多看看堆和栈的关系,看看发现又设计到gc(GarbageCollection)垃圾回收机制,发现盲区太多了,就去粗略的学习了一下jvm(java虚拟机),发现之前只会写程序,底......
  • os模块的使用方法详解
    os模块os模块负责程序与操作系统的交互,提供了访问操作系统底层的接口;即os模块提供了非常丰富的方法用来处理文件和目录。使用的时候需要导入该模块:importos常用方法如......
  • Flutter帧率监控 | 由浅入深,详解获取帧率的那些事
    前言做线上帧率监控上报时,少不了需要弄明白如何通过代码获取实时帧率的需求,这篇文章通过图解配合Flutter性能调试工具的方式一步步通俗易懂地让你明白获取帧率的基础知识,以......
  • linux命令详解
    万字详解Linux常用指令(值得收藏)运维网工 2023-01-0109:00 发表于重庆收录于合集#linux命令12个#linux11个#linux常用命令4个来源:https://blog.csdn.n......
  • Flutter帧率监控 | 由浅入深,详解获取帧率的那些事
    前言做线上帧率监控上报时,少不了需要弄明白如何通过代码获取实时帧率的需求,这篇文章通过图解配合Flutter性能调试工具的方式一步步通俗易懂地让你明白获取帧率的基础知识,......
  • 5. Pytest自定义前置后置:fixture参数详解(了解)
    一、前言我们上节课讲到fixture自定义前置函数的时候,有5个非必填参数,scope,params,autouse,ids,name。一般情况下这五个参数我们在工作中都不常用,但是个别情况会用到,这节......
  • 7. Pytest参数化:parametrize参数详解(了解)
    一、前言上节课我们讲解了如何用parametrize装饰器进行参数化,它有5个参数,argnames,argvalues,indirect,ids,scope,本节课针对这五个参数做详细讲解。二、学习目标1.a......
  • Target EDI 对接详解 1– Partner Online EDI 注册
    Target塔吉特是美国仅次于Walmart沃尔玛的第二大巨型折扣零售百货集团,在2020财年实现零售收入同比增长19.8%,赶超了CVS和Tesco,并在2020财年的销售额增长超过150亿美元......
  • Python之configparser模块详解和使用
    (目录)1configparser安装pip3installconfigparser2configparser简介用来读取配置文件的python包;一般做自动化测试的时候,会使用到这个模块,用来封装一些常量。比如......