Vuex插件的安装与使用原理

Vuex插件的安装与使用原理

Vuex安装和环境搭建

安装Vuex

  • 第一步:打开CMD窗口,通过命令转到Vue的安装路径
  • 第二步:输入安装Vuex的命令
    • vue2 安装 Vuex3 版本:npm i vuex@3
    • vue3 安装 Vuex4 版本:npm i vuex@4
  • 当在CMD窗口末尾中出现added 1 package in 2m,表示安装完成

Vuex环境搭建

  • 第一步:在Vue文件路径下新建文件夹vuex,并在vuex(新建的文件夹)下创建store.js文件
    • 创建的store.js很重要,创建的文件名决定了之后的调用写法
  • 第二步:在store.js文件中输入以下代码
javascript 复制代码
// 引入Vue
import Vue from 'vue'
// 引入插件
import Vuex from 'vuex'

// 使用插件
Vue.use(Vuex)

// 负责执行行为的对象
const actions = {}
// 负责更新的对象
const mutations = {}
// 负责数据状态
const state = {}
// 负责接收state对象
const getters = {}

export default new Vuex.Store({
    actions,
    mutations,
    state,
    getters
})
  • 第三步:在main.vue文件中引入store.js文件
javascript 复制代码
import store from './vuex/store'

new Vue({
  el : '#app',
  // 不要忘记这里也要添加
  store,
  render: h => h(App),
})

Vuex使用原理

  • 原理:实现数据实时共享


actions(负责执行业务的对象)

  • 注意:以下的context和value并不是一定要写的,当你的业务简单(简单到可以只做一点代码就能完成要求,也不需要更新数据)或者可以跳过这个业务时,可以选择不写,直接通过this.$store.commit('mutations的方法名', value)转到mutations
javascript 复制代码
// xxx.vue
methods : {
    方法名(){
        this.$store.dispatch('actions方法名', 值)
    }
}

// 负责执行业务的对象
const actions = {
    方法名(context, value){
        ......对value执行的业务
        context.commit('这里写mutations的方法名', value)
    }
}
  • context:上下文,将所在方法的值(value)传到下一个(mutations)方法中
  • value:值,actions的值接收的是从xxx.vue文件中的this.$store.dispatch('actions方法名', 值)传过来的数据

mutations(负责更新数据的对象)

  • 对于actions和mutations中的方法名可以在命名时进行区分(一点小建议,当然两个写的一样也没关系)
    • 如actions中的方法名可以按照驼峰式的写法'saveUsername'
    • 而mutations的方法名可以按照全大写叫下划线分隔'SAVE_USERNAME'

传给mutations值的方法分两种:

  • 第一种:通过this.$store.dispatch('actions方法名', 值),将数据传给actions,再通过context.commit('mutations方法名', value)传给mutations方法名中。
javascript 复制代码
// xxx.vue
methods : {
    方法名(){
        this.$store.dispatch('actions方法名', 值)
    }
}

// 负责执行业务的对象
const actions = {
    方法名(context, value){
        ......对value执行的业务
        context.commit('这里写mutations的方法名', value)
    }
}

// 负责更新数据的对象
const mutations = {
    方法名(state, value){
        ......
    }
}
  • 第二种:通过this.$store.commit('mutations方法名', 值),将数据不经过actions的方式,直接传给mutations对象中。
    • 注意:这种只能在没有需要执行业务的情况下进行。
javascript 复制代码
// xxx.vue
methods : {
    方法名(){
        this.$store.commit('actions方法名', 值)
    }
}

// 负责更新数据的对象
// mutations中的对象名,要和actions中的context.commit('mutations中的方法名')一致
const mutations = {
    方法名(state, value){
        ......
    }
}
  • state:数据,接收actions对象中处理好的数据
  • value:值,更新到state的值

state(存放数据的对象,可以看做Vue的data)

  • 所有的数据存放的位置都从这里获取
javascript 复制代码
// 负责数据状态
const state = {
    xxx : '',
    xxx : [
        {id:xxx, name:xxx, age:xxx},
        {id:xxx, name:xxx, age:xxx},
        {id:xxx, name:xxx, age:xxx}
    ]
}

getters(自动接收state对象,可以看做Vue的computed)

javascript 复制代码
// xxx.vue
<template>
    <div>
        <h1>{{$store.getters.对象名}}</h1>
    </div>
</template>

// 自动接收state对象,可对数据进行额外操作,产生不同的效果
// 效果:反转、去除空白行、转大小写 等等
const getters = {
    方法名(state){
        return ......
    }
}
相关推荐
子春一18 分钟前
Flutter for OpenHarmony:用 Flutter 构建一个数字猜谜游戏:从零开始的交互式应用开发
javascript·flutter·游戏
Y淑滢潇潇29 分钟前
WEB 作业 三个练习题
前端·javascript·css3
EndingCoder1 小时前
性能优化:类型系统的最佳实践
linux·前端·javascript·ubuntu·性能优化·typescript
晚霞的不甘1 小时前
Flutter for OpenHarmony:注入灵魂:购物车的数据驱动与状态管理实战
android·前端·javascript·flutter·前端框架
Marshmallowc1 小时前
React useState 数据不同步?深度解析无限滚动中的“闭包陷阱”与异步更新丢失问题
前端·javascript·react.js·闭包·fiber架构
前端 贾公子1 小时前
npm 发包配置双重身份验证
前端·javascript·微信小程序·小程序·github
zhengfei6111 小时前
CVE-2025-55182 的 POC,可在 Next.js 16.0.6 上运行
开发语言·javascript·ecmascript
千寻技术帮1 小时前
10392_基于SpringBoot的大学迎新系统
mysql·vue·源码·springboot·代码·新生报到
weixin_BYSJ19872 小时前
django农作物批发交易系统--附源码24008
java·javascript·spring boot·python·django·flask·php
辰风沐阳2 小时前
ES6 新特性: 解构赋值
前端·javascript·es6