Vuex基础使用存取值+异步请求

简介: Vuex基础使用存取值+异步请求

一.Vuex简介

vuex是什么?

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



什么情况使用 Vuex?


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


如果您不打算开发大型单页应用,使用 Vuex 可能是繁琐冗余的。确实是如此——如果您的应用够简单,您最好不要使用 Vuex。一个简单的 store 模式就足够您所需了。但是,如果您需要构建一个中大型单页应用,您很可能会考虑如何更好地在组件外部管理状态,Vuex 将会成为自然而然的选择。


vuex使用场景:


当一个组件需要多次派发事件时。例如购物车数量加减。

跨组件共享数据、跨页面共享数据。例如订单状态更新。

需要持久化的数据。例如登录后用户的信息。

当您需要开发中大型应用,适合复杂的多模块多页面的数据交互,考虑如何更好地在组件外部管理状态时

vuex 的五个核心概念


  • State 定义状态(变量)
  • Getter 获取状态(变量的值)
  • Mutation 修改状态(修改变量的值)
  • Action 触发 mutation 函数,从而修改状态
  • Module 当状态很多时,把状态分开来管理

二、Vuex使用

2.1 Vuex安装

注意: node.js运行环境



1、node.js版本10输入下指令进行安装

npm install vuex

2、node.js版本18请执行下指令

npm i -S vuex@3.6.2

下载执行命令:


安装完成出现以下配置说明成功

创建store(仓库)模块



三、使用Vuex获取、修改值案例

在项目中创建store目录




state.js:

export default{
  eduName:'ar.小白',
  aname:'',
  bname:''
}

mutations.js:

export default {
  setEduName: (state, payload) => {
    state.eduName = payload.eduName;
  }
}


getters.js:

export default {
  getEduName: (state) => {
    return state.eduname;
  }
}


actions.js 先不写代码。

index.js:

import Vue from 'vue'
import Vuex from 'vuex'
import state from './state'
import getters from './getters'
import actions from './actions'
import mutations from './mutations'
Vue.use(Vuex)
const store = new Vuex.Store({
     state,
     getters,
     actions,
     mutations
 })
 export default store


3.2 引用

在src中的main.js进行引用,如下:

import store from './store'
/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  store,
  data(){
    return{
      Bus:new Vue()
    }
  },
  components: { App },
  template: '<App/>'
})


3.1 创建两个菜单组件

page1:

<template>
    <div>
        <h1>page1</h1>
        <p>请输入您要修改的值</p>
    <input type="text" v-model="msg">
    <button @click="changed">修改参数值</button>
    <button @click="getData">获取参数值</button>
    </div>
  </template>
  <script>
  export default {
    data () {
      return {
        msg: 'page1'
      }
    },
    methods:{
      changed(){
        this.$store.commit('setName',{Name:this.msg})
      },
      getData(){
        let name = this.$store.getters.getName;
        alert(name);
      }
}
  }
  </script>
  <style>
  </style>

page2:

<template>
    <div>
        <h1>page2</h1>
        {{change}}
    </div>
  </template>
  <script>
  export default {
    data () {
      return {
        msg: 'page2'
      }
    },
    computed:{
      change(){
        return this.$store.getters.getName;
      }
    }
  }
  </script>
  <style>
  </style>


到项目中src的router的index.js文件中配置路径,如下:

1. import page1 from '@/Views/vuex/page1'
2. import page2 from '@/Views/vuex/page2
{
        path: '/vuex/page1',
        name: 'page1',
        component: page1
      },
      {
        path: '/vuex/page2',
        name: 'page2',
        component: page2
      }

模拟菜单数据

 <!-- 模拟数据 -->
<el-submenu key="key_999" index="index_999">
      <template slot="title">
        <span slot="title">Vuex管理</span>
      </template>
      <el-menu-item key="key_99901" index="/vuex/page1">
        <span>page1</span>
      </el-menu-item>
      <el-menu-item key="key_99902" index="/vuex/page2">
        <span>page2</span>
      </el-menu-item>
    </el-submenu>
  </el-menu>

效果展示:


四.Vuex的同步异步


解释:


同步操作:

同步操作是指立即执行并修改应用程序状态的操作。在 Vuex 中,这通常通过 mutations 来实现。Mutations 是用于修改状态的函数,它们必须是同步的,这意味着它们不应该包含异步代码。当你需要在应用程序中执行一些立即生效的状态变更时,同步操作是非常有用的。


异步操作:

异步操作是指可能需要一些时间来执行的操作,例如数据获取、网络请求、或其他需要等待的任务。在 Vuex 中,这通常通过 actions 来处理。Actions 是用于分发异步任务的函数,它们可以包含异步代码,例如异步 API 调用,然后在异步操作完成后提交 mutations 来修改状态。


异步操作适用于需要等待的任务,因为它们不会阻塞应用程序的其他操作,使得应用可以继续响应用户的输入。你可以在异步操作中使用异步 JavaScript 特性,如 Promises 或 async/await,来管理异步代码。


4.1 异步改变值

1、src/store/actions.js

export default {
  setNameSync: (context, payload) => {
    //context指的是vuex的上下文
    setTimeout(function() {
      context.commit('setName', payload)
    }, 3500)
  }
};


2、在page1.vue组件添加异步事件

<button @click="Asynchronization">异步改变参数值</button>
    Asynchronization() {
        this.$store.dispatch('setNameSync', {
          name: this.msg
        })
      }



效果图:

目录
相关文章
Vue3 跨组件传参 provide 与 inject
Vue3 跨组件传参 provide 与 inject
175 0
|
10月前
|
人工智能 边缘计算 云计算
2024.11|云计算行业的商业模式创新方法及实践
截至2024年,全球云计算行业迈入全新阶段,从IaaS到大规模AI模型平台,技术与商业模式不断创新。本文分析全球最新技术进展,探讨云计算商业模式创新策略与实践,解析云服务厂商如何通过技术革新实现价值最大化,推动企业数字化与智能化转型。重点讨论AI与云计算的深度融合、边缘计算与去中心化发展、平台化与生态系统建设,以及数据安全与绿色云计算等关键议题。
664 30
ElementUI——elementui2.0表格支持render渲染
ElementUI——elementui2.0表格支持render渲染
300 0
|
缓存 NoSQL Linux
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
262 1
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
|
缓存 JavaScript UED
使用 v-once 和 v-memo 进行 Vue 渲染优化
使用 v-once 和 v-memo 进行 Vue 渲染优化
|
JavaScript 测试技术 API
如何从 Vue 2 无痛升级到 Vue 3,一文搞定!
如何从 Vue 2 无痛升级到 Vue 3,一文搞定!
|
JSON 关系型数据库 MySQL
第09章 性能分析工具的使用【2.索引及调优篇】【MySQL高级】4
第09章 性能分析工具的使用【2.索引及调优篇】【MySQL高级】4
224 0
|
存储 Web App开发 Ubuntu
整理16款适用于较旧低配置电脑的最佳Linux发行版
在本指南中,趣云笔记(https://www.ecscoupon.com/)介绍了一些最好的Linux发行版,你可以将它们安装在旧PC上并为其注入新的活力。
19626 0
|
JavaScript
js类型校验的方式
js类型校验的方式
100 1
|
监控 安全 编译器
常用问题排查工具和分析神器,值得收藏
常用问题排查工具和分析神器,值得收藏