快速入门——状态管理VueX

Vuex介绍

状态管理

每一个Vuex应用的核心都是一个store,与普通的全局对象不同的是,基于Vue数据与视图绑定的特点,当store中的状态发生变化时,与之绑定的视图也会被重新渲染。

store中的状态不允许被直接修改,改变store中的状态的唯一途径就是显示地提交,这可以让我们方便地跟踪每一个状态的变化。

在大型复杂应用中,如果无法有效地跟踪到状态的变化,将会对理解和维护代码带来极大的困难。

Vuex中有5个重要的概念:State,Getter,Mutation,Action,Module

State用于维护所有应用层的状态,并确保应用只有唯一的数据源.Mutation提供修改State状态的方法

//创建一个新的store实例

const store = createStore({

state (){

return {

count: 0

}

},

mutations:{

increment(state){

state.count++

}

}

})

在组件中,可以直接使用this.$store.state.count访问数据,也可先用mapState辅助函数将其映射下来。

//单独构建的版本中辅助函数为Vuex.mapState

import { mapState } from 'vuex'

export default{

coputed: mapState({

count:state => state.count.

countAlias: 'count',

countPlusLocalState(state){

return state.count+this.localCount

}

})

}

Mutation同步操作

在组件中,可以直接使用store.commit来提交mutation

复制代码
method:{
    increment(){
        this.$store.commit('increment')
        console.log(this.$store.state.count)
    }
}

也可以先用mapMutation辅助函数将其映射下来

复制代码
methods: {
    ...mapMutations([
        'increment',
        'incrementBy'
        
    ])
},

Getter维护由State派生的一些状态,这些状态随着State状态的变化而变化

Action

类似于Mutation,适合做异步操作

Action不能直接修改状态,只能通过提交mutation来修改

复制代码
const store = createStore({
    state: {
        count: 0
    },
    mutations: {
        increment(state){
            state++
        }
    },
    actions: {
        increment(context){
            context.commit('increment')
        }
    }


})
相关推荐
旧梦吟2 分钟前
脚本网页 地球演化
前端·算法·css3·html5·pygame
xiaoxue..5 分钟前
哨兵节点与快慢指针解决链表算法难题
前端·javascript·数据结构·算法·链表
这是个栗子5 分钟前
【前端知识点总结】前端跨域问题
前端·跨域·cors
尽欢i11 分钟前
踩过坑才懂:前端生成唯一 ID,别用 Date.now ()了!一行代码搞定
前端·javascript
JS_GGbond11 分钟前
解锁 JavaScript 对象的“魔法宝箱”:这些方法让你玩转对象操作
前端·javascript
Doris89313 分钟前
【JS】JS进阶--编程思想、面向对象构造函数、原型、深浅拷贝、异常处理、this处理、防抖节流
开发语言·javascript·ecmascript
是杉杉吖~15 分钟前
《5 分钟上手 React Flex 容器:从 0 搭建响应式卡片列表》
前端·react.js·前端框架
福大大架构师每日一题16 分钟前
rust 1.92.0 更新详解:语言特性增强、编译器优化与全新稳定API
java·javascript·rust
仰望.17 分钟前
vue 甘特图 vxe-gantt table 拖拽任务调整开始日期和结束日期的使用,拖拽任务调整日期
vue.js·甘特图·vxe-ui
阿懂在掘金19 分钟前
早点下班:在 Vue3 中少写 40%+ 的异步代码
vue.js