vue_vuex笔记

Vuex 状态管理

0. 前言

  • 核心:Vuex 是 Vue 全局状态管理库
  • 作用:多组件共享数据、统一管理数据
  • 适用:用户信息、购物车、全局配置、订单状态等

一、安装命令

bash 复制代码
npm install vuex@next --save

二、Vuex 核心概念(必背)

  1. state
    定义共享数据
  2. mutations
    定义同步修改数据的方法
  3. actions
    定义异步操作,调用 mutations
  4. getters
    对 state 数据加工(类似计算属性)

三、Vuex 固定结构(store/index.js)

js 复制代码
import Vuex from 'vuex'

export default Vuex.createStore({
  // 1. 共享数据
  state: {
    count: 0,
    username: ""
  },

  // 2. 同步修改 state
  mutations: {
    SET_COUNT(state, num) {
      state.count = num
    },
    SET_USER(state, name) {
      state.username = name
    }
  },

  // 3. 异步操作
  actions: {
    asyncSetCount({ commit }, num) {
      setTimeout(() => {
        commit('SET_COUNT', num)
      }, 1000)
    }
  },

  // 4. 加工数据
  getters: {
    doubleCount(state) {
      return state.count * 2
    }
  }
})

四、使用共享数据(组件中)

1. 获取数据

js 复制代码
this.$store.state.count
this.$store.state.username

2. 调用 mutations(同步修改)

js 复制代码
this.$store.commit('SET_COUNT', 100)

3. 调用 actions(异步修改)

js 复制代码
this.$store.dispatch('asyncSetCount', 200)

4. 使用 getters

js 复制代码
this.$store.getters.doubleCount

五、Vuex 流程(必背)

  1. 组件 dispatch 调用 actions
  2. actions commit 调用 mutations
  3. mutations 修改 state
  4. state 改变 → 所有使用数据的组件自动更新

六、Vuex 核心规则(面试必问)

  • state 只读,不能直接改
  • 修改必须走 mutations
  • mutations 必须同步
  • 异步操作必须放在 actions
  • 数据共享、响应式、所有组件可访问

七、一句话总结

  • state:存数据
  • mutations:改数据(同步)
  • actions:异步处理,调用 mutations
  • commit → 调用 mutations
  • dispatch → 调用 actions
相关推荐
前端 贾公子1 小时前
从零开始:使用Node.js和Cheerio进行轻量级网页数据提取
前端·vue.js
Hua-Jay1 小时前
OpenCV联合C++/Qt 学习笔记(十九)----图像分割
c++·笔记·qt·opencv·学习
七爷不在我这里1 小时前
dockerB站笔记
笔记·docker
奋斗的小乌龟1 小时前
langchain4j笔记-07-tool
笔记
user297525876121 小时前
使用SSE实现流式渲染实践
前端·javascript
LPieces1 小时前
【LPieces-UI】02-Icon组件的设计与实现
前端·vue.js
卤蛋fg61 小时前
vxe组件 vxe-table 权限控制:通过 permission-code 实现按钮级显隐
vue.js
東隅已逝,桑榆非晚1 小时前
深⼊理解指针(4)
c语言·笔记
大大杰哥1 小时前
2025ccpc南昌补题笔记(前六题)
c++·笔记·算法