6-1-vue3框架-vuex中的store(仓库)的用法

vuex介绍

Vuex是什么?为什么要用它?

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。可以想象为一个“前端数据库”(数据仓库),让其在各个页面上实现数据的共享包括状态,并且可操作

vuex官方解释
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 + 库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

大家可以思考一下,组件之间的传值有哪些?有父子通讯,兄弟组件通讯......但是传参对于多层嵌套就显得非常繁琐,代码维护也会非常麻烦。因此vuex就是把组件共享状态抽取出来以一个全局单例模式管理,把共享的数据函数放进vuex中,任何组件都可以进行使用。

什么时候我们该使用它?
Vuex 可以帮助我们管理共享状态,并附带了更多的概念和框架。这需要对短期和长期效益进行权衡。

2,Vuex分成五个部分:
1.State:单一状态树
2.Getters:状态获取
3.Mutations:触发同步事件
4.Actions:提交mutation,可以包含异步操作
5.Module:将vuex进行分模块

vuex安装使用

  1. vuex使用步骤
    3.1 安装
    npm install vuex@3.4.0 -S

    3.2 创建store模块,分别维护state/actions/mutations/getters
    store
    index.js
    state.js
    actions.js
    mutations.js
    getters.js
    3.3 在store/index.js文件中新建vuex的store实例,并注册上面引入的各大模块
    const store = new Vuex.Store({state,getters,actions,mutations})

     3.4 在main.js中导入并使用store实例
    
               new Vue({
                           el: '#app',
                           router,
                           store, //在main.js中导入store实例
                           components: {
                                        App
                            },
                            template: '<App/>',
                            data: {
                                //自定义的事件总线对象,用于父子组件的通信
                                 Bus: new Vue()
                           }
                  })
    

  1. vuex的核心概念:store、state、getters、mutations、actions

    4.0 store
    每一个Vuex应用的核心就是store(仓库),store基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。
    const store = new Vuex.Store({
    state, // 共同维护的一个状态,state里面可以是很多个全局状态
    getters, // 获取数据并渲染
    actions, // 数据的异步操作
    mutations // 处理数据的唯一途径,state的改变或赋值只能在这里
    })

在vue中,store用于管理状态、共享数据以及在各个组件之间管理外部状态,store是vuex应用的核心,也就是一个容器,包含着应用中大部分的状态,更改store中的状态唯一方法是提交mutation。

vue里store的用法是什么

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

每一个 Vuex 应用的核心就是 store(仓库)。“store”基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。Vuex 和单纯的全局对象有以下两点不同:

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

你不能直接改变 store 中的状态。改变 store 中的状态的唯一途径就是显式地提交 (commit) mutation。这样使得我们可以方便地跟踪每一个状态的变化,从而让我们能够实现一些工具帮助我们更好地了解我们的应用。

store 的核心概念

state 表示了 store 中的状态,类似于 vue 实例中的 data 属性。

Mutation

更改 Vuex 的 store 中的状态的唯一方法是提交 mutation。

Vuex 中的 mutation 非常类似于事件:每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数

Action

Action 类似于 mutation,不同在于:

Action 提交的是 mutation,而不是直接变更状态。

Action 可以包含任意异步操作。

posted @ 2023-01-29 15:45  技术改变命运Andy  阅读(709)  评论(0编辑  收藏  举报