【Vuex】入门使用---详细介绍

news2024/11/18 8:30:50

一,Vuex入门

1.1 什么是Vuex

        Vuex是一个专门为Vue.js应用程序开发的状态管理库。它用于管理应用程序中的共享状态,它采用集中式存储管理应用的所有组件的状态使得状态的管理变得简单和可预测

官方解释Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。可以想象为一个“前端数据库”(数据仓库), 让其在各个页面上实现数据的共享包括状态,并且可操作

1.2 Vuex的核心概念

  1. State(状态):使用单一状态树来存储应用程序的所有状态。该状态树是响应式的,当状态发生变化时,组件会自动更新。

  2. Getter(获取器):用于从状态中派生出新的状态。通过计算属性或方法,在获取器中可以对状态进行处理,从而得到新的值。

  3. Mutation(突变):用于修改状态的唯一方式。每个突变都是一个纯函数,接受当前的状态和一些可选的额外参数作为输入。在突变中,可以对状态进行同步修改。

  4. Action(动作):类似于突变,但是不直接修改状态。动作提交突变来改变状态。动作可以包含异步操作、以及对突变的多次提交。

  5. Module(模块):将应用程序的状态拆分成多个模块,每个模块拥有自己的状态、获取器、突变和动作。通过模块化的方式,可以更好地组织和管理状态。

1.3 Vuex优点

①集中化管理状态,方便状态的跟踪和调试

②组件之间共享状态,减少了组件间的通信复杂度

③提供了一套规范和约束,使得状态的变化可追踪和可预测

④支持插件扩展,可以通过插件增加额外的功能

二,Vuex的使用

2.1 vuex使用步骤

2.1.1 安装

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

     npm install vuex -S  

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

       npm i -S vuex@3.6.2

注意:spa项目工作区间使用cmd终端命令窗口执行

2.2.2 创建store模块

 每一个Vuex应用的核心就是store(仓库),store基本上就是一个容器,它包含着你的应用中大部分的状态 (state)

store模块所需要的js文件:

 index.js

 state.js :共同维护的一个状态,state里面可以是很多个全局状态

  actions.js :数据的异步操作

  mutations.js :获取数据并渲染

   getters.js  :获取数据并渲染

结构:

2.2.3 在store/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

2.2.4 main.js中导入并使用store实例

import store from './store'

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

3.1 创建两个组件

如下 pageone与pagetwo组件

3.2  配置路由

src/router/index.js

import pageone from '@/views/vuex/pageone'
import pagetwo from '@/views/vuex/pagetwo'

3.3 模拟菜单数据

  <!-- 模拟数据 -->
    <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/pageone">
        <span>pageone</span>
      </el-menu-item>
      <el-menu-item key="key_99902" index="/vuex/pagetwo">
        <span>pagetwo</span>
      </el-menu-item>
    </el-submenu>

3.4 vuex核心操作

①在state.js中定义全局参数

state.js:

export default{
	eduName:'我不是打工人'
}

②在mutations.js中改变值

mutations.js:

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

③在getters.js中获取参数值

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

3.5 效果

扩展:在别的页面上同样可以获取到state的值

pagetwo.vue组件编写:

 computed:{
   eduName(){
    return this.$store.state.eduName
	 }
}

三,Vuex异步请求处理

3.1 异步改变值

actions.js:异步改变state的值

export default{
	setEduNameAsync:(context,payload)=>{
		setTimeout(function(){
			context.commit('setEduName',payload);
		},5000);
	}
}

在刚刚的Vue组件中新增一个按钮和点击事件

 fun3(){
      this.$store.dispatch('setEduNameAsync',{eduName:this.msg})
	  }

效果展示:

3.2 异步发送Ajax到后端

后端代码:

package com.zking.ssm.controller;

import com.zking.ssm.util.JsonResponseBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import java.text.SimpleDateFormat;
import java.util.Date;

@RestController
@RequestMapping("/vuex")
public class VuexController {

    @RequestMapping("/queryVuex")
    public JsonResponseBody<?> queryVuex(HttpServletRequest request) {
        String resturantName = request.getParameter("resturantName");
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String date = sdf.format(new Date());
        try {
            System.out.println("模拟异步情况,睡眠6秒,不能超过10秒,axios超时时间设置的是10秒!");
            Thread.sleep(6000);
            System.out.println("睡醒了,继续...");
        } catch (Exception e) {
            e.printStackTrace();
        }
        return new JsonResponseBody<>(resturantName + "-" + date,true,0,null);
    }
}

在api文件夹下的action.js设置后台请求的地址的封装(URL)

'VUEX_AJAX': '/vuex/queryVuex', // 异常Ajax请求后端

actions.js:异步发送ajax到后端

 setEduNameAjAX:(context, payload) => {
	    let _this=payload._this;
	    let url = _this.axios.urls.VUEX_AJAX;
	    let params = {
	      resturantName: payload.eduName
	    }
	    _this.axios.post(url, params).then(r => {
	    console.log(r)
	 
	    }).catch(r => {
	 
	    });
	  }

在Vue组件中新增一个按钮和点击事件

  fun4(){
	    this.$store.dispatch('setEduNameAjAX',{eduName:this.msg, _this:this})
			  }

效果展示:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1082233.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端本地存储方案-localForage-vue3中使用

前言 前端有多种本地存储方案可供选择&#xff0c;常见的有&#xff1a; Cookie&#xff1a;小型的文本文件&#xff0c;存储少量数据Web Storage &#xff1a;包括&#xff1a;localStorage和sessionStorage&#xff0c;存储数据有上限&#xff08;5M&#xff09;左右Indexe…

JVM面试题:(三)GC和垃圾回收算法

GC: 垃圾回收算法&#xff1a; GC最基础的算法有三种&#xff1a; 标记 -清除算法、复制算法、标记-压缩算法&#xff0c;我们常用的垃圾回收器一般 都采用分代收集算法。 标记 -清除算法&#xff0c;“标记-清除”&#xff08;Mark-Sweep&#xff09;算法&#xff0c;如它的…

优化|一类二元二次规划的凸重构和外近似

论文解读者&#xff1a;范若岭 1. 文章优化问题&#xff1a; 对于下列问题&#xff0c;$ \mathbb{B} {0, 1}, \mathbb{R} 是实数集合。 是实数集合。 是实数集合。Q 是由实数组成的 是由实数组成的 是由实数组成的n \times n 对称矩阵。 对称矩阵。 对称矩阵。A 是由实数组成…

NSIDC定义的海冰相关概念

文章目录 相关概念Matlab绘图结果展示 相关概念 NSIDC 表示 “National Snow and Ice Data Center”&#xff0c;即美国国家雪和冰数据中心。NSIDC 是一个位于美国科罗拉多大学波尔得分校的研究中心&#xff0c;致力于收集、管理和分发全球雪和冰的科学数据。 Matlab绘图 cl…

智能井盖传感器:破解井盖安全隐患

万宾科技&#xff1a;智能井盖传感器 随着城市的不断发展&#xff0c;井盖成为城市道路的一部分&#xff0c;但也伴随着一些安全隐患。近年来&#xff0c;由于井盖倾斜或翻转导致的意外事件频发&#xff0c;引起了广泛关注。为了解决这一问题&#xff0c;万宾科技推出了智能井…

3、TCP状态

TCP状态 1、TCP通信时序 三次握手成功后&#xff0c;服务器和客户端进入了状态ESTABLISHED 当处于Time_WAIT状态后&#xff0c;不会马上变成CLOSE状态&#xff0c;会经历2MSL&#xff08;约40秒&#xff09;&#xff0c;之后才会进入CLOSE状态。 总结&#xff1a; 主动发起…

主动配电网故障恢复的重构与孤岛划分matlab程序

微❤关注“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 参考文档&#xff1a; A New Model for Resilient Distribution Systems by Microgrids Formation&#xff1b; 主动配电网故障恢复的重构与孤岛划分统一模型&#xff1b; 同时考虑孤岛与重构的配电网故障…

java 电动车销售管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 java 电动车销售管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql…

深度学习_2_数据处理

import os是一个Python的内置模块&#xff0c;用于与操作系统进行交互。通过导入os模块&#xff0c;你可以使用其中提供的函数和方法来执行各种与操作系统相关的任务。 import osos.makedirs(os.path.join(.., date), exist_okTrue)##将创建一个名为date的文件夹&#xff0c;位…

基于全景运动感知的飞行视觉脑关节神经网络全方位碰撞检测

https:/doi.org/10.1155/2023/5784720 摘要&#xff1a; 生物系统有大量的视觉运动检测神经元&#xff0c;其中一些神经元可以优先对特定的视觉区域做出反应。然而&#xff0c;关于如何使用它们来开发用于全向碰撞检测的神经网络模型&#xff0c;很少有人做过工作。为此&#…

相同的 key, Nacos 配置一定会覆盖 application.yaml 吗?

一&#xff0c;背景&#xff1a; 之前在使用 Nacos 的时候有个疑问&#xff0c;同样的 key&#xff0c;在 Nacos 配置了&#xff0c;在 application 也配置了&#xff0c;到底会有哪个呢&#xff1f;一直没空查&#xff0c;后来在网上看到过文章&#xff0c;说 Nacos 是在 app…

【Redis】Hash 哈希相关的命令

命令 HSET 设置hash中指定的字段&#xff08;field&#xff09;的值&#xff08;value&#xff09;。 HSET key field value [field value ...]HGET 获取hash中指定字段的值。 HGET key fieldHEXISTS 判断hash中是否有指定的字段。 HEXISTS key fieldHDEL 删除hash中指定…

第十一章-用户进程

Ⅰ.为什么需要任务状态段TSS 1.LDT简介 已经不使用LDT加载任务了。因为当前运行的任务&#xff0c;其 LDT 位于 LDTR 指向的地址&#xff0c;这样 CPU 才能从中拿到任务运行所需要的资源&#xff08;指令和数据&#xff09;。因此&#xff0c;每切换一个任务时&#xff0c;需…

Android Jetpack Compose之生命周期与副作用

文章目录 1.概述2.Composeable生命周期3.Compose副作用及API3.1.Compose副作用API3.1.1 DisposableEffect3.1.2 SideEffect 3.2 Compose异步处理副作用API3.2.1 LaunchedEffect3.2.2 rememberCoroutineScope3.2.3 rememberUpdateState3.2.4 snapshotFlow 3.3 状态创建副作用API…

什么是C++?

1.什么是C C语言是结构化和模块化的语言&#xff0c;适合处理较小规模的程序。对于复杂的问题&#xff0c;规模较大的 程序&#xff0c;需要高度的抽象和建模时&#xff0c;C语言则不合适。为了解决软件危机&#xff0c; 20世纪80年代&#xff0c; 计算机 界提出了OOP(object o…

一种管理KEIL工程输出文件的方法

开发语言&#xff1a;python&#xff1b; 针对工程&#xff1a;适配ARM公司的KEIL-V5软件的工程 管理的输出文件类型&#xff1a;BIN文件、HEX文件 脚本使用方法&#xff1a;直接放置到keil的设置项下&#xff1b; 脚本执行位置&#xff1a;程序编译之后 脚本功能&#xff1a…

C++智能指针(一)——shared_ptr初探

文章目录 1. 普通指针存在的问题2. Class shared_ptr2.1 使用 shared_ptr2.1.1 初始化 shared_ptr2.1.2 reset2.1.3 访问数据2.1.4 use_count() 3. Deleter3.1 定义一个 Deleter3.2 处理数组 1. 普通指针存在的问题 智能指针的引入&#xff0c;是为了解决普通指针在使用过程中…

Android 13.0 SystemUI修改状态栏电池图标样式为横屏显示

1.概述 在13.0的产品定制化开发中,对于原生系统中SystemUId 状态栏的电池图标是竖着显示的,一般手机的电池图标都是横屏显示的 可以觉得样式挺不错的,所以由于产品开发要求电池图标横着显示和手机的样式一样,所以就得重新更换SystemUI状态栏的电池样式了 如图: 2.SystemUI…

区块链金融的开发流程

区块链金融应用的开发流程与一般的软件开发流程有许多相似之处&#xff0c;但它还涉及到智能合约的编写、区块链网络集成和加密货币处理等特定方面的工作。以下是一般区块链金融应用的开发流程&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件…

如何查自己名下有多少个微信号?

99%的人都不知道微信有这个功能通过微信可以查自己名下绑定了多少个微信账号再也不担心身份证被别人用来绑定微信了姐妹们快去查一下吧&#xff01; ①打开微信&#xff0c;点击【我】→点击【设置】 ②点击【通用】→ 点击【辅助功能】→ 点击【微信支付】 ③点击【帮助中心】…