【Vue】vuex-五个核心

这篇具有很好参考价值的文章主要介绍了【Vue】vuex-五个核心。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

🚩🚩🚩
💎个人主页: 阿选不出来
💨💨💨
💎个人简介: 一名大二在校生, 不定时更新自己学习道路上的一些笔记.
💨💨💨
💎目前开发的专栏: JS 🍭Vue🍭JS进阶
💨💨💨
💎接上一篇 Vue-条件,列表渲染-key的底层原理

vuex

1.什么是vuex

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

2.什么时候用Vuex

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

Vuex 可以帮助我们管理共享状态,并附带了更多的概念和框架。这需要对短期和长期效益进行权衡。如果您不打算开发大型单页应用,使用 Vuex
可能是繁琐冗余的。如果您需要构建一个中大型单页应用,您很可能会考虑如何更好地在组件外部管理状态,Vuex 将会成为自然而然的选择。

3.搭建vuex环境

  1. 安装:
npm install vuex@next --save
  1. 创建文件: src/store/index.js
// 引入Vue核心库
import Vue from 'vue'
// 引入Vuex
import Vuex from 'vuex'
//应用Vuex插件
Vue.use(Vuex)

//准备actions对象---响应组件中用户的动作
const actions = {}
//准备mutation对象---修改state中的数据
const mutation = {}
//准备state对象---保存具体的数据
const state = {}

// 创建并暴露store
export default new Vuex.store({
    actions,
    mutation,
    state
})

main.js中创建vm时传入 store配置项

......
// 引入store
import store from './store'
......

//创建vm
new  Vue({
    el: '#app',
    render: h => h(app),
    store
})

4.五个核心

基础使用:

  1. 初始化数据, 配置 action, 配置 mutations , 操作文件 store.js
// 引入Vuex 核心库
import Vue from 'vue'
// 引入Vuex
import Vuex from 'vuex'
// 引用Vuex
Vue.use(Vuex)

const actions = {
    //响应组件中的动作
    jia(context, value) {
       context.commit('JIA',value)
    },
    jian(context, value) {
        context.commit('JIAN', value)
    }
}

const mutations = {
    //执行加
    JIA(state, value) {
        state.sum += value
    }
}

// 初始化数据
const state = {
    sum:0
}

//创建并暴露store
export default new Vuex.Store({
    actions,
    mutations,
    state
})
  1. 组件中读取vuex中的数据: $store.state.sum
  2. 组件中修改vuex中的数据: $store.dispatch('action中的方法名', 数据)$store.commit('mutation中的方法名', 数据)

备 注 : 若 没 有 网 络 请 求 或 其 他 业 务 逻 辑 , 组 件 中 也 可 以 越 过 a c t i o n s , 既 不 写 d i s p a t c h , 直 接 编 写 c o m m i t 备注: 若没有网络请求或其他业务逻辑, 组件中也可以越过actions, 既不写 dispatch, 直接编写commit :,actions,dispatch,commit

State

用于初始化数据,提供唯一的公共数据源,所有共享的数据统一放到store的state进行储存,相似与data

组件内通过 this.$store.state.count 访问到.
HTML内通过 $store.state.count 访问到.

Mutation

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

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

  mutations: {
    increment (state) {
      // 变更状态
      state.count++
    }
  }

调用
在组件中使用:this.$store.commit('increment')
提交载荷 : this.$store.commit('increment',10) 你可以向 store.commit 传入额外的参数,即 mutation 的载荷(payload), 参数可以是字符串也可以是对象.
对象风格的提交方式:

this.$store.commit({
  type: 'increment',
  amount: 10
})

注意::: mutation 必须是同步函数

Action

Action 提交的是 mutation,而不是直接变更状态。 Action 可以包含任意异步操作。

使用-参数
Action 函数接受一个与 store 实例具有相同方法和属性的 context 对象,因此你可以调用 context.commit 提交一个 mutation,或者通过 context.statecontext.getters 来获取 state 和 getters。
调用
在组件内 : this.$store.dispatch('increment')

// 以载荷形式分发
this.$store.dispatch('incrementAsync', {
  amount: 10
})

// 以对象形式分发
this.$store.dispatch({
  type: 'incrementAsync',
  amount: 10
})

getters

  1. 概念: 当state中的数据需要经过加工后在使用时, 可以使用getters加工.
  2. store.js 中追加 getters 配置
......
const getters = {
    bigSum(state){
        return state.sum * 10
    }
}

//创建并暴露store
export default new Vuex.store({
    ......
    getters
})
  1. 组件中读取数据: $store.getters.bigSum

Modules

  1. 目的: 让代码更好维护, 让多种数据分类更加明确.
  2. 修改 store.js
const countAbout = {
    namespaced:true,
    actions:{.....},
    mutations:{.....},
    state:{......},
    getters:{...},
}
           
const personAbout = {
    namespaced:true,
    actions:{.....},
    mutations:{.....},
    state:{......},
    getters:{...},
}
           
const store = new Vue.store({
     modules: {
           countAbout,
           personAbout
          }
})
  1. 开启命名空间后, 组件中读取state数据:
// 方式一: 自己直接读取
this.$store.state.personAbout.list
// 方式二: 借助mapState读取
...mapState('countAbout',['sum','school', 'subject'])
  1. 开启命名空间后, 组件中读取getters数据:
// 方式一: 自己直接读取
this.$store.getters['personAbout/firstPersonName']
// 方式二: 借助mapGetters读取
...mapGetters('countAbout',['bigSum'])
  1. 开启命名空间后, 组件中调用dispath
// 方式一: 自己直接dispath
this.$store.dispath('personAbout/addPersonWang', person]
// 方式二: 借助mapActions读取
...mapActions('countAbout',{incrementOdd: 'jiaOdd', incrementWait: 'jiaWait'})
  1. 开启命名空间后, 组件中调用commit
// 方式一: 自己直接commit
this.$store.commit('personAbout/ADD_PERSON',person)
// 方式二: 借助mapMutations读取
...mapMutations('countAbout',{increment: 'JIA', decrement: 'JIAN'})

5.四个map方法的使用

  1. mapState方法: 用于帮助我们映射 state 中的数据为计算属性.

    computed: {
        //借助mapState生成计算属性, sum,school,subject (对象写法)
        ...mapState({sum:'sum', school:'school', subject:'subject'})
        
        //借助mapState生成计算属性, sum,school,subject (数组写法)
        ...mapState(['sum','school','subject'])
    }
    

    2.**mapGetters方法:**用于帮助我们映射 getters中的数据为计算属性.

    computed: {
        //借助mapGetters生成计算属性, bigSum (对象写法)
        ...mapGetters({bigSum:'bigSum'}),
            
        //借助mapGetters生成计算属性, bigSum (数组写法)
         ...mapGetters(['bigSum']),
    }
    
    1. **mapActions方法:**用于帮助我们生成与 action 对话的方法, 即 : 包含 $store.dispath(xxx) 的函数
    methods: {
        //靠mapActions生成, incrementOdd, incrementWait (对象形式)
        ...mapActions({incrementOdd:'jiaOdd', incrementWait:'jiaWait'}),
         //靠mapActions生成, incrementOdd, incrementWait (数组形式)
        ...mapActions(['jiaOdd','jiaWait']),
    }
    
    1. mapMutations方法: 用于帮助我们生成与 mutations 对话的方法, 即: 包含 $store.commit(xxx) 的函数
    methods: {
        //靠mapMutations生成, increment, decrement (对象形式)
         ...mapActions({increment:'JIA', decrement:'JIAN'}),
         //靠mapMutations生成, JIA,JIAN (数组形式)
         ...mapActions(['JIA','JIAN']),
    }
    

    📢📢📢写在最后

  • 看到这里有没有收获什么呢?🎀🎀🎀

  • 🎈🎈有错误的地方可以在评论区留言,本博会虚心改正的

  • 觉的博主写的不错的,可以给个一键三连lia~✨✨文章来源地址https://www.toymoban.com/news/detail-426008.html

到了这里,关于【Vue】vuex-五个核心的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Vuex状态管理】Vuex的基本使用;核心概念State、Getters、Mutations、Actions、Modules的基本使用

    在开发中,应用程序需要处理各种各样的数据,这些数据需要保存在应用程序中的某一个位置,对于这些数据的管理就称之为是 状态管理。 在前面是如何管理自己的状态呢? 在Vue开发中,使用组件化的开发方式; 而在组件中定义data或者在setup中返回使用的数据,这些数据称

    2024年02月07日
    浏览(33)
  • 【vue】vuex持久化插件vuex-persistedstate:

    一、说明: Vuex是在中大型项目中必不可少的状态管理组件,刷新会重新更新状态,但是有时候我们并不希望如此。例如全局相关的,如登录状态、token、以及一些不常更新的状态等,我们更希望能够固化到本地,减少无用的接口访问,以及更佳的用户体验。 页面刷新后,想

    2024年02月09日
    浏览(39)
  • Vue(Vuex插件)

    专门在Vue中实现 集中式状态数据管理的一个Vue插件 ,对Vue的应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信。 https://github.com/vuejs/vuex https://github.com/vuejs/vuex 当通过全局事件总线或者消息订阅与发布传递信息时候,

    2024年02月06日
    浏览(23)
  • 【Vue】学习笔记-Vuex

    概念:专门在vue中实现集中式状态(数据) 管理的一个vue插件,对Vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信 Vuex Gihub地址 多个组件依赖于同一状态 来自不同组件的行为需要变更同一状态 。 使用纯vue编写 sr

    2024年02月07日
    浏览(21)
  • VUE--VUEX

    Vuex就是一个vue的状态(数据)管理工具 ,是vue项目实现大范围数据共享的技术方案。能够方便、高效的实现组件之间的数据共享。 Vuex的好处 :         (1)数据的 存储一步到位 ,不需要层层传递         (2)数据的 流动十分清晰         (3)存储在Vuex中的 数据

    2024年01月25日
    浏览(17)
  • vue~vuex的使用

    Vuex 和本地存储(如 localStorage )以及 cookie 存储(如 document.cookie )之间有一些关系,但它们是不同的概念,用于不同的目的。 Vuex : Vuex 是 Vue.js 的官方状态管理库,用于在 Vue.js 应用程序中管理应用程序的全局状态。 Vuex 主要用于在前端应用程序中存储和管理各种状态,包

    2024年02月09日
    浏览(33)
  • 【Vue】VueX仓库

            📝个人主页:五敷有你        🔥系列专栏:Vue ⛺️稳中求进,晒太阳 目录 Vue概述 是什么 场景: 优势 构建多组件共享环境 创建一个空仓库 核心概念 - state 状态 1. 提供数据 2.使用数据 ​编辑 通过辅助函数(简化) 核心概念 - mutations 步骤: 传参: 辅助函数

    2024年03月13日
    浏览(21)
  • vue2 vuex

    Vuex 是一个 Vue 的 状态管理工具 ,状态就是数据。 大白话:Vuex 是一个插件,可以帮我们管理 Vue 通用的数据 (多组件共享的数据) 。 使用场景 某个状态 在 很多个组件 来使用 (个人信息) 多个组件 共同维护 一份数据 (购物车) 优势 共同维护一份数据, 数据集中化管理 响应式

    2024年02月09日
    浏览(23)
  • Vue-搭建Vuex开发环境

    安装之前需要了解一个版本问题,在vue2中,要用vuex的3版本,在vue3中,要用vuex的4版本,要严格遵循这个版本要求,不然就会出现各种意想不到的问题,例如下方安装报错,就算因为版本问题 安装的方式也有好几种,我这里采用的是npm安装 npm Yarn 我这里用的是vue2,所以就安

    2024年02月10日
    浏览(29)
  • vue 安装并配置vuex

    1.安装vuex命令: npm i vuex@3.6.2 2.全局配置 在main文件里边导入-安装-挂载 main.js页面配置的 配置成功后会出现这个页面 我这个是给谷歌浏览器安装了一个vue插件谷歌浏览器安装vue2 vue插件 index.js页面 main.js页面

    2024年02月12日
    浏览(19)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包