前端八股文 vuex的理解

概念

vuex 是一个专门为vue.js应用程序开发的状态管理库

核心概念:

1.每一个 Vuex 应用的核心就是store(仓库)。 (全局共享的属性(数据))

"store" 基本上就是一个容器,它包含着你的应用中大部分的状态 ( state)。

2.Vuex 的状态存储是响应式的 。当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变 化,那么相应的组件也会相应地得到高效更新。

3.改变 store 中的状态的唯一途径就是显式地提交 (commit) mutation 。这样可以方便地跟踪每一个 状态的变化

图示

Vuex为Vue Components建立起了一个完整的生态圈,包括开发中的API调用一环。

(1)核心流程中的主要功能: (根据上图更好的理解 )

Vue Components 是 vue 组件,组件会触发**(dispatch)一些事件或**动作,也就是图中的

Actions;

在组件中发出的动作,肯定是想获取或者改变数据 的,但是在 vuex 中,数据是集中管理的,不能 直接去更改数据,所以会把这个动作提交(Commit)到 Mutations 中 ; 然后 Mutations 就去改变**(Mutate)State 中的数据**;

State 中的数据被改变之后,就会重新渲染(Render)到 Vue Components 中去 ,组件展示更 新后的数据,完成一个流程

getters ∶ state对象读取方法 。图中没有单独列出该模块,应该被包含在了render中,Vue Components通过该方法读取全局state对象

state (单一状态树) getter/Mutation 显示提交更改 state

Action类似Mutation ,提交 Mutation ,可以包含任意异步操作。

module (当应用变得庞大复杂,拆分 store 为具体的 module 模块)

(store 中的数据只能由 mutations 来修改 vuex中总结的有

actions 可以用来同时执行多个mutations ,并且可以很好的处理异步过程。)

2. Vuex中action和mutation的区别 (自己总结更好)

Mutation专注于修改State,理论上是修改State的唯一途径;Action业务代码、异步请求。

Mutation:必须同步执行;Action:可以异步,但不能直接操作State。

在视图更新时,先触发actions,actions再触发mutation

mutation的参数是state,它包含store中的数据;store的参数是context,它是 state 的父级,包 含 state、getters

相关推荐
夏幻灵32 分钟前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_1 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝1 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions1 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发1 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_1 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞051 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
我爱加班、、1 小时前
Websocket能携带token过去后端吗
前端·后端·websocket
AAA阿giao1 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
杨超越luckly1 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强