IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vuex原理、用法、与事件总线区别详解 -> 正文阅读

[JavaScript知识库]Vuex原理、用法、与事件总线区别详解

Vuex与全局事件总线

在这里插入图片描述

上图是使用全局事件总线进行多组件数据共享,如果组件BCD需要获得组件A中的数据,或者A需要回调BCD中的数据,需要频繁地调用eventbus,操作复杂且繁琐。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iAKEpaF6-1639055644685)(C:\Users\13704\AppData\Roaming\Typora\typora-user-images\image-20211209155336864.png)]

上图是通过Vuex实现多组件数据共享,将组件ABCD需要共享的数据存储在了Vuex组件中,这样相当于只需要单次进行组件间地双向通信即可共享到数据。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tloXfUGt-1639055644686)(C:\Users\13704\AppData\Roaming\Typora\typora-user-images\image-20211209203730656.png)]

Vuex与事件总线的本质区别

  • eventBus利用事件抛发的原理进行传递数据
  • Vuex是响应式的,和数据双向绑定的原理一样,使用了gettersetter进行数据劫持

Vuex是什么

专门在Vue中实现集中式状态(数据)管理的一个Vue插件,对Vue应用中多个组件的共享状态进行集中式的管理,也是一种组件间通信的方式,且适用于任意组件间通信。Vuex 也集成到 Vue 的官方调试工具 devtools extension (opens new window),提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。

Vuex的优势

  • 能够在vuex中集中管理共享的数据,便于开发和后期进行维护
  • 能够高效的实现组件之间的数据共享,提高开发效率
  • 存储在vuex中的数据是响应式的,当数据发生改变时,页面中的数据也会同步更新

使用Vuex的场景

  • 多个组件依赖于同一状态
  • 来自不同组建的行为需要变更同一状态

Vuex原理图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3lJFxTQQ-1639055644690)(C:\Users\13704\AppData\Roaming\Typora\typora-user-images\image-20211209160613234.png)]

  • Actions,Mutations,State都是Object对象

  • actions用于响应组件中的动作

  • mutations用于操作数据(state)

  • state用于存储数据

PS:若没有网络请求或其他业务逻辑,组件中也可以越过actions,即不写dispatch,直接编写commit

Vuex的用法

  1. 安装Vuex
  2. 创建Store对象管理数据
  3. 挂载Store对象到Vue实例
  • 安装Vuex

    npm i -S vuex
    
  • 创建Store对象管理数据

    ①创建src/store目录,并在其中创建vuex.js文件用于导入并创建Store对象

    ②编写src/store/index.js文件

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({
    // state中存放的就是全局共享的数据
    state: {count: 0}
})

Vue.use(Vuex) 顺序一定要在 new Vuex.Store 之前

  • 挂载 Store 对象到 Vue 实例
import store from '@/store/vuex'

new Vue({
    router,
    store,
    render: (h) => h(App),
}).$mount("#app");

State、Getters、Mutations、Actions、Modules

https://vuex.vuejs.org/zh/guide/state.html

这里最好把官方文档都仔细看一遍

Getters

getter是对 Store中已有的数据加工处理形成新的数据,类似Vue的计算属性,Store数据发生变化,则 getter中的数据也会跟着变化

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-10 10:58:30  更:2021-12-10 11:00:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 2:03:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码