当前位置: 首页 > news >正文

vue stores全局状态共享

目录

一、个人理解

二、安装

三、登录案例


一、个人理解

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

二、安装

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

npm install pinia

三、登录案例

1、主文件去创建并挂载Pinia到vue app应用。

import { createApp } from 'vue'
import App from './App.vue'
import router from './router/main'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
// import locale from 'element-plus/es/locale/lang/zh-cn'
import * as Icons from '@element-plus/icons-vue'
import zhCn from 'element-plus/es/locale/lang/zh-cn' // 引入中文语言包

import { createPinia } from 'pinia'


// createApp(App).use(router).mount('#app')
const app = createApp(App)

app.use(createPinia())
app.use(router)
app.use(ElementPlus, {
    locale: zhCn,
  })
// 注册所有图标为全局组件
Object.keys(Icons).forEach((key) => {
    app.component(key, Icons[key])
  })


app.mount('#app')

2、vue项目中新建stores文件夹,新建userStore.js文件。

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

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

<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>

相关文章:

  • alphafold3本地部署
  • 划分字母区间
  • 【Qt】常用控件(一)
  • 【练习】【二分】力扣热题100 153. 寻找旋转排序数组中的最小值
  • C++ Qt建立一个HTTP服务器
  • 鸿蒙开发:V2版本装饰器之@Monitor装饰器
  • 阐解WiFi信号强度
  • Linux centOS7 bash编程小技巧
  • Vue3中的setup
  • Linux应用之构建命令行解释器(bash进程)
  • vue3之echarts柱状图-圆锥加自动轮播
  • 使用Termux将安卓手机变成随身AI服务器(page assist连接)
  • Pyrhon函数-装饰器第一部分250219
  • C程序设计(第5版)——谭浩强(2)
  • 构建简单RAG代码实现
  • java常见面试场景题
  • nodejs各版本下载地址 —— 筑梦之路
  • 【Java】泛型与集合篇 —— 泛型
  • virt-io 如何运行在 kvm windows 虚拟机上
  • rust学习三、基本类型
  • 澎湃读报丨央媒头版集中刊发社论,庆祝“五一”国际劳动节
  • 马上评|扩大高速免费救援范围,打消出行后顾之忧
  • 过去24小时中美是否就关税问题进行过接触?外交部:没有
  • 金砖国家外长会晤落幕,外交部:发出了反对单边霸凌行径的“金砖声音”
  • 招商蛇口:一季度营收约204亿元,净利润约4.45亿元
  • 新希望一季度归母净利润4.45亿,上年同期为-19.34亿