【Vue】之Vuex的入门使用,取值,修改值,同异步请求处理---保姆级别教学

简介: 【Vue】之Vuex的入门使用,取值,修改值,同异步请求处理---保姆级别教学

一,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})
        }

效果展示:

目录
相关文章
|
4天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
37 1
|
14天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
46 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
32 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
39 1
vue学习第四章
|
2月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
30 1
vue学习第7章(循环)
|
2月前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
34 1
vue学习第九章(v-model)
|
2月前
|
JavaScript 前端开发 开发者
vue学习第十章(组件开发)
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文深入讲解Vue组件的基本使用、全局与局部组件、父子组件通信及数据传递等内容,适合前端开发者学习参考。持续更新中,期待您的关注!🎉🎉🎉
47 1
vue学习第十章(组件开发)

热门文章

最新文章