Vuex学习笔记

介绍

  • Vuex是为Vue.js应用程序开发的状态管理模式,采用集中式存储管理所有组件的状态,通俗来讲,是为了实现任意组件之间的通信,其主要包含四个模块:
    image
  • state:保存整个应用的状态(数据)
  • mutations:改变状态的唯一方式,同步操作
  • actions:类似mutation,异步操作
  • vue components:vue组件

安装

  • 在项目目录下使用npm或cnpm:
npm install vuex --save
image
  • 安装完成后再次下载依赖
npm install

使用

  • 安装完成后,建议在src目录下单独创建一个文件夹,用于保存vuex的js脚本文件


    image
  • 在文件中引入vue和vuex
import Vue from 'vue'
import Vuex from 'vuex'
  • 使用引入后,切记引用vuex
Vue.use(Vuex)
image

Vuex倡导存、读、写分离

State(存)

  • state负责存储整个应用的状态数据,在需要使用的时候在根节点注入store对象,注入后使用this.$store.state获取状态
image

image

image
  • 重命名该状态:
    • 通过计算属性computed直接赋值:


      image
    • 通过mapState进行赋值:

      computed: 
          mapState({
              nameFromMapState: state => state.person.name,
              ageFromMapState: state => state.person.age,
              genderFromMapState: state => state.person.gender,
          })
      
    • mapState的更简单写法:若映射的属性名称与state的子节点名称相同时,可采用字符串数组的形式简写

      mapState(['person','time'])  //映射this.person为store.state.person
      

getters(读)

  • getter属性可以认为是store的计算属性,它接收state作为第一个参数
image
  • getters暴露一个store.getters对象,通过这个对象访问其内部数据
this.$store.getters.getYear
  • getters也可用mapGetters进行改名:
mapGetters({
    yearFromMapGetters: 'getYear',
    monthFromMapGetters: 'getMonth',
    dayFromMapGetters: 'getDay',
})

mutations

  • 唯一更改store中状态的方法
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Vuex 是什么? ** 官方解释:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式**。它采用集中...
    Rz______阅读 2,326评论 1 10
  • vuex 状态管理器 作为应用中所有组件的中央储存 只能以预定的方式去操作状态 把所有组件共享的状态抽取出来作为全...
    一只大椰子阅读 807评论 0 1
  • 安装 npm npm install vuex --save 在一个模块化的打包系统中,您必须显式地通过Vue.u...
    萧玄辞阅读 2,972评论 0 7
  • VUEX 是一个状态管理模式,可以集中式存储和管理组件的状态。 组件使用store里面的state作数据展示,通过...
    Liberty寒风阅读 1,237评论 1 1
  • 知识点: css之nth-child(),first-child(),last-child() eval() vu...
    woow_wu7阅读 728评论 0 0