关于Vuex的简单实际应用

简介: 关于Vuex的简单实际应用

Vuex是什么?

Vuex是一个专为 Vue.js 应用程序开发的状态管理模式 + 库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。简单来说就是:应用遇到多个组件共享状态时,使用vuex。

应用场景以及流程

  • 多个组件共享数据或者是跨组件传递数据时。
  • 页面通过mapAction异步提交事件到action,action通过commit把对应参数同步提交到mutation,mutation会修改state中对应的值。最后通过getter把对应值跑出去,在页面的计算属性中,通过mapGetter来动态获取state中的值。

属性

  • state:vuex的基本数据,用来存储变量
  • geeter:从基本数据(state)派生的数据,相当于state的计算属性
  • mutation:提交更新数据的方法,必须是同步的(如果需要异步使用action)。每个mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数,提交载荷作为第二个参数。
  • action:和mutation的功能大致相同,不同之处在于:

               Action 提交的是 mutation,而不是直接变更状态。

               Action 可以包含任意异步操作。

  • modules:模块化vuex,可以让每一个模块拥有自己的state、mutation、action、getters,使得结构非常清晰,方便管理。

安装

npm install vuex --save

在src下新建vuex文件夹,在vuex文件夹下新建store.js并引入、注册vuex。

//引入
import Vue from 'vue'
import Vuex from 'vuex'
//注册
Vue.use(Vuex)
const store = new Vuex.Store({
    modules:{
    }
  });
export default store;

举例(账号密码保存)

image.png

在vuex文件夹下新建user.js并进行相关配置,同时再将上面配置好的store.js再进行修改。

user.js

const user = {
    state:{
      user:"",
      password:""
    },
    mutations:{
      USER_INFO(state,data){
        state.user = data
      },
      USER_INFO_PWD(state,data){
        state.password = data
      }
    },
    actions:{
      saveUserInfo({ commit },data){
        commit('USER_INFO',data)
      },
      saveUserPwd({ commit },data){
        commit('USER_INFO_PWD',data)
      }
    },
    getters:{
        getName:(state)=>state.user,
        getPwd:(state)=>state.password
    }
  };
  export default user

store.js

//引入
import Vue from 'vue'
import Vuex from 'vuex'
import user from './api/user'
//注册
Vue.use(Vuex)
const store = new Vuex.Store({
    modules:{
      user
    }
  });
export default store;

main.js

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

Login.vue(关键代码)

         this.axios.post('接口', {
              userId: _this.loginForm.userId,
              passWord: _this.loginForm.passWord
         }).then(response => {
              if (response.data.length) {
                //请求回来后,把用户信息存储到VUEX里
              this.$store.dispatch('saveUserInfo', response.data[0].userId);
              this.$store.dispatch('saveUserPwd', response.data[0].passWord);
                //页面跳转
               this.$router.push("/Home");
               this.$message({
                  message: '恭喜你,登录成功',
                  type: 'success'
                });
             }
              else {
               this.$message.error('请检查用户名或密码');
             }
          })

Home.vue

<template>
  <a>{{Name}}</a>
</template>
import { mapGetters } from 'vuex'
  export default {
    data() {
      return {
      };
    },
    computed: {
      Name() {
        return this.$store.getters.getName;
          }
      },
    mounted() {
      //在页面加载时读取sessionStorage里的状态信息
      if (sessionStorage.getItem("store")) {
  this.$store.replaceState(Object.assign({}, this.$store.state, JSON.parse(sessionStorage.getItem("store")))
      }
      //在页面刷新时将vuex里的信息保存到sessionStorage里
      window.addEventListener("beforeunload", () => {
        sessionStorage.setItem("store", JSON.stringify(this.$store.state))
      })
    }
    }
  };
</script>

效果如下:

image.png

image.png

文章知识点与官方知识档案匹配,可进一步学习相关知识


相关文章
|
机器学习/深度学习 PyTorch TensorFlow
[深度学习入门]Numpy基础(上)
[深度学习入门]Numpy基础(上)
|
5月前
|
存储 人工智能 JSON
传统OCR集体阵亡!Versatile-OCR-Program:开源多语言OCR工具,精准解析表格和数学公式等复杂结构
本文解析开源OCR工具Versatile-OCR-Program的技术实现,其基于多模态融合架构实现90%以上识别准确率,支持数学公式与图表的结构化输出,为教育资料数字化提供高效解决方案。
642 5
传统OCR集体阵亡!Versatile-OCR-Program:开源多语言OCR工具,精准解析表格和数学公式等复杂结构
|
JSON 文字识别 算法
使用InternVL、LMDeploy和GTE搭建多模态RAG系统
如何将视觉大模型(VLM)与 多模态RAG 结合起来,创建服装搜索和搭配推荐!本文展示了InternVL模型在分析服装图像和提取颜色、款式和类型等关键特征方面的强大功能。
|
10月前
|
SQL
HiveSql数据比对通用写法
hivesql进行两张表的数据对比
138 2
|
10月前
|
开发框架 前端开发 JavaScript
利用Python和Flask构建轻量级Web应用的实战指南
利用Python和Flask构建轻量级Web应用的实战指南
586 2
|
10月前
|
存储 缓存 JavaScript
一文带你了解vuex和使用(2024年11月)
欢迎来到我的博客,我是自学前端两年半的大一学生,熟悉JavaScript与Vue,正向全栈发展。本篇介绍了Vuex,Vue.js的状态管理模式,包括其核心概念如state、getter、mutation、action及模块化使用,通过集中管理状态确保应用状态的可预测变化。文章详细解析了Vuex的工作原理,特别是与Vue的computed属性和响应式系统的集成,以及如何在实际项目中搭建和使用Vuex。如果你觉得有帮助,欢迎关注,我将持续更新更多技术文章。🎉🎉🎉
911 0
|
安全 关系型数据库 MySQL
"深度解析:MySQL密码修改与远程登录配置全攻略,保障数据库安全与灵活访问"
【8月更文挑战第9天】MySQL是广受青睐的开源关系型数据库系统,其安全性和易用性对DBA和开发者至关重要。本文通过实例解析MySQL中用户密码更新及远程登录配置,确保数据库安全访问与高效管理。首先介绍如何分步修改密码,包括登录MySQL、选择数据库、使用`ALTER USER`命令更新密码,并刷新权限。接着,指导如何配置远程访问,涉及调整MySQL监听地址、授权用户远程登录、检查网络设置及测试远程连接。遵循这些步骤,可强化数据库安全性并实现灵活管理。
742 0
|
网络安全 API Python
Python下载大文件时遇到了SSL握手失败,要怎么办?
在 Python 数据集下载中常遇程序中断问题, 如网络不稳定、API请求数量限制等。网络不稳定时可通过实现重试机制与使用短效代理IP应对。示例代码利用 `requests` 库实现自动重试功能,提高下载成功率。对于 API 请求数量限制,可通过控制请求速率和轮换代理IP解决。示例展示了如何控制请求间隔及使用代理池轮换来避免触发限制。这些技巧有助于确保下载任务的顺利进行。
|
JavaScript
vue 组件封装——可自由拖拽移动的盒子
vue 组件封装——可自由拖拽移动的盒子
176 0
|
安全 Java Apache
十个方法破解Java生成随机密码的小窍门
十个方法破解Java生成随机密码的小窍门