Vuex的基本使用总结

本文总结了Vuex的使用,包括Vuex的安装、创建store、核心概念如State、Mutation、Action和Getter。Vuex作为组件全局状态管理工具,提供响应式数据并简化组件间的数据共享。通过Mutation进行同步数据变更,Action处理异步任务,并通过Getter进行数据处理。文章强调了何时使用Vuex以及如何避免在Mutation中进行异步操作。
摘要由CSDN通过智能技术生成

1.Vuex概述

Vuex是实现组件全局状态(数据)管理的一种机制,可以方便的实现组件之间的数据共享。

使用Vuex管理数据的好处:

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

什么样的数据适合存储到 Vuex 中
一般情况下,只有组件之间共享的数据,才有必要存储到vuex中;对于组件中的私有数据,依旧存储在组件自身的 data 中即可。

2.vuex的使用

  1. 安装 vuex 依赖包
    npm install vuex --save
    
  2. 导入 vuex 包
    import vuex from 'vuex'
    Vue.use(vuex)
    
  3. 创建 store 对象
    const store = new Vuex.Store({
         
    	// state 中存分的就是全局共享的数据
    	state: {
          count: 0 }
    })
    
  4. 将 store 对象挂载到 vue 实例中
    new Vue({
         
    	el:  '#app',
    	render: h => h(app),
    	router,
    	// 将创建的共享数据对象,挂载到 Vue 实例中
    	// 所有的组件都可以直接从 store 中获取全局的数据
    	store
    })
    

3. Vuex的核心概念

3.1 State

State 提供唯一的公告数据源,所有共享的数据都要统一放到 Store 的 State 中进行存储。

// 创建 store 数据源,提供唯一公共数据
	const store = new Vuex.Store({
   
		state: {
    count: 0 }
	})

组件访问 State 中数据的第一种方式:

this.$store.state.全局数据名称
// this.$store.state.count

组件访问 State 中数据的第二种方式:mapState

// 1. 从 vuex 中按需导入 mapState 函数
import {
    mapState } from 'vuex'

通过刚才导入的 mapState 函数,将当前组件需要的全局数据,映射为当前组件的 computed 计算属性:

// 2. 将全局数据,映射为当前组件的计算属性
computed: {
   
...mapState(['count'])
}
<template
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值