vue stores全局状态共享

目录

一、个人理解

二、安装

三、登录案例


一、个人理解

作为一个后端开发,我个人觉得这个stores性质有点类似于全局变量。相等于后端里的一个全局的字典对象,在后端中,我们需要通过全局变量/对象去判断处理相关逻辑,同样store可以为前端处理达到这种效果,vue的store支持在不同的组件中引入,引入的组件可以访问/设置store对象值,拿到唯一的值。

二、安装

使用npm安装,需要有node环境。

复制代码
npm install vuex

三、登录案例

vue项目中新建stores文件夹,新建UseStore.js文件。

javascript 复制代码
import { defineStore } from "pinia";
import { ref } from "vue";

export const useUserStore = defineStore('userStore', () => {
    const userName = ref('')

    function setUserName(value){
        userName.value = value
    }

    return { userName, setUserName}
})

登录页面组件中,通过引入UseStore.js文件,可以调用useUserStore对象。

bash 复制代码
<template>
pass
</template>

<script setup>
  import { ref, reactive, onMounted } from 'vue';
  import axios from 'axios';
  import { useRoute, useRouter } from 'vue-router';
  import { ElMessage } from 'element-plus';
  import { useUserStore } from '@/stores/userStore.js';
  
  const store = useUserStore()

  const route = useRoute()
  const router = useRouter()

  const loginParams = reactive({
    'userName': '',
    'password': '',
  })

  const rules = reactive({
    userName: [{required: true, message: '请输入用户名', trigger: 'blur'}],
    password: [{required: true, message: '请输入密码', trigger: 'blur'}]
  })

  const user = ref(null)
  const loading = ref(null)
  const error = ref(null)
  const total = ref(0)


  function userLogin (){
    loading.value = true
    axios.post('http://123:456/login', loginParams)
    .then((res) => {
      # 设置登录用户
      store.setUserName(loginParams.userName)

      // 登录成功跳转页面路由,store.userName获取store变量值
      ElMessage.success(`用户:${store.userName},欢迎回来!`)
      router.push({ name: 'handle'})
    })
    .catch(() => {
      ElMessage.error('用户名或密码错误!')
      loading.value = false
    })
    .finally(() => {
      loading.value = false
    })
  }

<style scoped>
pass
</style>
相关推荐
小白6402几秒前
2025年终总结-迷途漫漫,终有一归
前端·程序人生
烟花落o5 分钟前
贪吃蛇及相关知识点讲解
c语言·前端·游戏开发·贪吃蛇·编程学习
kgduu5 分钟前
js之javascript API
javascript
晚霞的不甘9 分钟前
Flutter for OpenHarmony专注与习惯的完美融合: 打造你的高效生活助手
前端·数据库·经验分享·flutter·前端框架·生活
BYSJMG15 分钟前
计算机毕设选题推荐:基于大数据的癌症数据分析与可视化系统
大数据·vue.js·python·数据挖掘·数据分析·课程设计
kogorou0105-bit19 分钟前
前端设计模式:发布订阅与依赖倒置的解耦之道
前端·设计模式·面试·状态模式
止观止36 分钟前
像三元表达式一样写类型?深入理解 TS 条件类型与 `infer` 推断
前端·typescript
xiaoqi9221 小时前
React Native鸿蒙跨平台实现图片画廊类页面是视觉展示型APP(如摄影类、图库类、设计类APP)的核心载体,其核心需求是实现图片的流畅渲染
javascript·react native·react.js·ecmascript·harmonyos
chenhdowue1 小时前
vue3甘特图 vxe-gantt 行内显示子任务,拆分任务展示同时可拖拽调整任务日期
vue.js·甘特图·vxe-gantt
雪芽蓝域zzs1 小时前
uniapp 省市区三级联动
前端·javascript·uni-app