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
相关推荐
用户2136610035721 小时前
Vue2组件化开发与父子通信
前端·vue.js
用户2136610035721 小时前
Vue2事件系统与指令进阶
前端·vue.js
labixiong1 小时前
实现一个能跑的迷你版Promise(一)
前端·javascript·面试
逸铭5 小时前
Day 5:三栏布局——左账号 / 中聊天 / 右工具
vue.js·electron
用户1733598075376 小时前
Vue 3 SPA 首屏优化:从 3s 到 1.2s 的 5 个实践
前端·vue.js
weedsfly6 小时前
还在用 Axios?你可能需要重新理解 XHR 与 Fetch
前端·javascript·面试
CoderWeen6 小时前
从零实现一个 Vue3 流程图编辑器:节点拖拽、贝塞尔连线与框选
前端·javascript
To_OC16 小时前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
kyriewen20 小时前
我用 50 行代码重写了 React Router 核心,终于搞懂了前端路由原理
前端·javascript·react.js
Asize1 天前
HTML5 Canvas 基础:从按帧动画到 ECharts 数据可视化
前端·javascript·canvas