VUEX

作者: xuan241 | 来源:发表于2017-05-05 11:30 被阅读40次

凌晨四点多惊醒,杂事纷呈,再难入眠。浑浑噩噩坐上地铁,坐地铁的近一个小时时间看了CSDN的老师讲vuex的视频,确实解惑不少...

state

what?

state是整个应用的数据中心,管理整个应用的状态。也称为状态对象

定义

一般是定义在store/index.js中,就是一个大的对象(或者单独来一个state.js引进来)。

  const state = {
    count: 0,
    history: []
  }
  const store = new Vuex.Store({
    state
  })

使用

  • 直接在组件模板里:{{$store.state.count}}
  • 在计算属性里面使用:
  computed: {
    count () {
      return this.$store.state.count
    }
  }
  • 最高级的用法:
  computed:{
    ...mapState([
      count
    ])
  }

mutations

what?

我把它理解为直接操作状态对象的操作中心

定义

一般是定义在store/mutations.js中,里面暴露了多个函数来改变状态对象

  export const increment = state => {
    state.count++
    state.history.push('increment')
  }

使用

  mothods: {
    ...mapMutations([
      increment
    ])
  }

getters

what?

getter可以看作是state的计算属性,即通过状态对象衍生出来的数据。从它的名字为getter可以看出,通过读取state得到衍生值

定义

一般是定义在store/getters.js中,里面暴露了许多值,这些值都是通过函数返回值赋值(通过这种方式可以避免在组件内直接使用mapState这种局限性较大方式)

  export const count = state => state.count

使用

  computed: {
    ...mapGetters([
      count
    ])
  }

actions

what?

action用来派发mutation,一个action中可以触发多个mutation,在不同的时间不同的条件下触发不同的mutation(异步操作在此处执行)

定义

一般是定义在store/actions.js中,里面暴露了很多方法。方法里面触发mutation(函数默认的第一个参数是context,下例使用了对象的结构)

  export const incrementIfOdd = ({ commit, state }) => {
    if ((state.count + 1) % 2 === 0) {
      commit('increment')
    }
  }

  export const incrementAsync = ({ commit }) => {
    setTimeout(() => {
      commit('increment')
    }, 1000)
  }

使用

  mothods: {
    ...mapActions([
      incrementIfOdd,
      incrementAsync
    ])
  }

module

what?

用来将上述种种进行模块化

定义

  const moduleA = {
    state,
    getters,
    actions,
    mutations
  }
  export default new Vuex.Store({
    modules: {
      moduleA
    }
  })

使用

实际上就是在state后面多加了一层moduleA(我们那些可爱的映射函数都没法用了)

相关文章

  • VUEX基本介绍,包含实战示例及代码(基于Vue2.X)

    VUEX 1 VUEX基本介绍 1.1 官方API 1.2 什么是vuex 1.3 Vuex使用场景 1、Vuex...

  • 【文档笔记】-Vuex

    什么是vuex? vuex文档: https://vuex.vuejs.org/zh/[https://vuex....

  • vuex配置

    vuex配置 目录 vuex的五个核心 配置vuex vuex持久化 一、vuex五个核心概念 State 定义状...

  • Vuex

    安装Vuex cnpm install vuex --save-dev Vuex是什么? 这是[Vuex的官网](...

  • Vuex

    1.Vuex概述 2.Vuex基本使用 3.使用Vuex完成todo案例 1.Vuex概述 Vuex是实现组件全局...

  • vuex

    Vuex介绍: Vuex官网:http://vuex.vuejs.org/ Vuex是实现数据状态管理的技...

  • vuex+axios 的开发流程记录

    相关文档 vuex: https://vuex.vuejs.org/zh/ 是否有必要使用vuex vuex是vu...

  • 2019-06-07

    import Vue from 'vue'import Vuex from 'vuex'Vue.use(Vuex)...

  • 配置 vuex 和 vuex 本地持久化

    配置 vuex 和 vuex 本地持久化 目录 vuex是什么 vuex 的五个核心概念State 定义状态(变量...

  • vuex

    配置 vuex 和 vuex 本地持久化 目录 vuex是什么 vuex 的五个核心概念State 定义状态(变量...

网友评论

      本文标题:VUEX

      本文链接:https://www.haomeiwen.com/subject/kjijtxtx.html