SSM项目实战-前端-将uid存放在pinia中

https://pinia.vuejs.org/zh/getting-started.html

1、安装pinia

npm install pinia
{"name": "pro20-schedule","private": true,"version": "0.0.0","type": "module","scripts": {"dev": "vite","build": "vite build","preview": "vite preview"},"dependencies": {"axios": "^1.6.2","element-plus": "^2.4.2","pinia": "^2.1.7","vue": "^3.3.8","vue-router": "^4.2.5"},"devDependencies": {"@vitejs/plugin-vue": "^4.5.0","vite": "^5.0.0"}
}

2、store/sysUserStore.js

import {defineStore} from "pinia";export const userStore = defineStore('sysUser',{state:()=>{return{uid: 1,}},getters: {},actions:{},
})

3、Login.vue

<script setup></script><template><div class="common-layout"><el-container><el-header height="120px">&nbsp;</el-header><el-container><el-aside width="36%">&nbsp;</el-aside><el-container><el-main><el-form :model="form" label-width="120px"><el-form-item label="用户名:"><el-input v-model="form.username" input-style="width:200px"/></el-form-item><el-form-item label="密&nbsp&nbsp码:"><el-inputv-model="form.userPwd"type="password"placeholder="Please input password"show-passwordinput-style="width:200px"/></el-form-item><el-form-item><el-button type="primary" @click="doLogin">登录</el-button><el-button>注册</el-button></el-form-item></el-form></el-main><el-footer>&nbsp;</el-footer></el-container></el-container></el-container></div>
</template><script lang="ts" setup>
import {reactive} from 'vue'
import {login} from "../api/sysUser.js";
import router from "../router/router.js";
import {userStore} from "../store/sysUserStore.js";let currUser = userStore();// do not use same name with ref
const form = reactive({username: 'lina',userPwd: '123456',
})const doLogin = async () => {let response = await login(form);let {code, flag, data, msg} = response.data;//console.log(data)if (code === 200 && flag) {currUser.uid=data.uidawait router.push('/index');}
}
</script>

4、main.js

import { createApp } from 'vue'
import App from './App.vue'import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import zhCn from 'element-plus/dist/locale/zh-cn.mjs'import router from "./router/router.js";import {createPinia} from 'pinia'let app = createApp(App);let pinia = createPinia();app.use(router)
app.use(pinia)
app.use(ElementPlus, {locale: zhCn,
})
app.mount('#app')

 5、Pinia

Pinia是Vue 3的一个官方状态管理库。它的存在主要是为了解决Vue 3中状态管理的问题。

在Vue 2中,我们通常使用Vuex来进行状态管理。Vuex使得我们能够在应用的不同部分之间共享状态,这对于构建大型、复杂的应用程序非常有用。然而,Vuex使用起来比较复杂,需要编写大量的代码,这对于简单的项目来说可能过于繁琐。

另一方面,Vue 3引入了Composition API,这是一个新的、更灵活的状态管理机制。Composition API让我们能够更清晰地组织代码,并且可以更轻松地进行单元测试。然而,Composition API并不提供像Vuex那样的集中式状态管理,这可能会导致在应用的不同部分之间共享状态变得困难。

Pinia就是在这种情况下出现的。它是Vue 3的官方状态管理库,旨在提供一种简单、易用的方式来在应用的不同部分之间共享状态。Pinia基于Vue 3的Composition API构建,因此它能够充分利用Composition API的优点,同时提供集中式状态管理的功能。

使用Pinia,我们可以在组件之间共享状态,而无需编写大量的代码。Pinia还提供了一些有用的功能,如将多个状态存储组合在一起、对状态进行持久化等。这使得我们能够更轻松地管理状态,同时保持代码的清晰和可维护性。

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

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

相关文章

什么是中间人攻击

中间人攻击 1. 定义2. 中间人攻击如何工作3. 常见中间人攻击类型4. 如何防止中间人攻击 1. 定义 中间人攻击&#xff08;Man-in-the-Middle Attack&#xff0c;简称MITM&#xff09;&#xff0c;是一种会话劫持攻击。攻击者作为中间人&#xff0c;劫持通信双方会话并操纵通信过…

全球与中国汽车电力电子市场:增长趋势、竞争格局与前景展望

目前&#xff0c;世界各国都致力于转向更环保、更永续的传统交通替代方案。 电动车满足所有要求&#xff0c;因为它们具有零废气排放、改善空气品质、减少温室气体排放并创造更清洁、更健康的环境。此外&#xff0c;电动车的运作成本比传统内燃机驱动的汽车低&#xff0c;因为…

企业微信群发助手:实现高效触达的关键利器

在当今的商业环境中&#xff0c;流量已经成为了每个企业争夺的宝贵资源&#xff0c;这也导致了获客成本的不断上升。为了解决这个问题&#xff0c;越来越多的企业开始转向私域流量的运营&#xff0c;通过私域来吸引和维护客户。以电商为例&#xff0c;商家通过客服引导用户添加…

【大连民族大学C语言CG题库练习题】——输入10个实数入数组,然后依次输出前1个实数和、前2个实数和、…、前10个实数和

【问题描述】输入10个实数入数组&#xff0c;然后依次输出前1个实数和、前2个实数和、…、前10个实数和 【输入形式】输入10个实数 【输出形式】依次输出前1个实数和、前2个实数和、…、前10个实数和 【样例输入】 1.2 3.4 4.4 3.8 5.1 6.2 7.3 4.3 9.4 2.5 【样例输出】 …

RabbitMQ 的七种消息传递形式

文章目录 一、RabbitMQ 架构简介二、准备工作 三、消息收发1. Hello World2. Work queues3. Publish/Subscrite3.1. Direct3.2. Fanout3.3. Topic3.4. Header 4. Routing5. Topics 大部分情况下&#xff0c;我们可能都是在 Spring Boot 或者 Spring Cloud 环境下使用 RabbitMQ&…

[C国演义] 第二十三章

第二十三章 两个字符串的最小ASCLL删除和最长重复子数组 两个字符串的最小ASCLL删除和 力扣链接 求 删除字符的ASCLL和的最小值 ⇒ 正难则反 ⇒ 求公共子序列的ASCLL和的最大值 两个数组的dp问题 ⇒ 分区间讨论 ⇒ dp[i][j] -- nums1数组的[0, i] 区间 和 nums2数组的[0, j] …

vue3学习网站

官方网站&#xff1a;Vue.js - 渐进式 JavaScript 框架 | Vue.js 中文文档: 简介 | Vue.js Webpack 入门教程&#xff1a;Webpack 入门教程 | 菜鸟教程 vue3知识宝库&#xff1a;Vue3

@Transactional事务以及相关的注解,事务的传播行为

Transactional是一个用于声明式事务管理的注解&#xff0c;通常用在 Spring 框架中。 当一个方法被 Transactional 注解时&#xff0c;表示该方法需要进行事务管理。如果方法执行过程中出现异常&#xff0c;那么事务会自动回滚&#xff1b;如果方法正常执行完毕&#xff0c;那…

【powerjob】定时任务调度器 xxl-job和powerjob对比

文章目录 同类产品对比资源及部署相关资源占用对比&#xff1a;部署方式&#xff1a;xxl job :调度器&#xff1a;执行器&#xff1a; powerjob&#xff1a;调度器&#xff1a;执行器&#xff1a; 总结 背景&#xff1a; 目前系统的定时任务主要通过Spring框架自带的Scheduled注…

华为云之一键安装宝塔面板

华为云之一键安装宝塔面板 一、本次实践介绍1.1 实践环境简介1.2 本次实践目的 二、宝塔面板介绍三、环境准备工作3.1 预置实验环境3.2 查看环境信息3.3 登录华为云3.4 查看弹性云服务器状态3.5 ssh登录弹性云服务器3.6 查看操作系统版本 四、安装宝塔面板4.1 一键部署宝塔面板…

【Java】判断一个字符串是否为数字型

问题 Testpublic void isNumeric1() {System.out.println("h185 >" isNumeric1("h185"));System.out.println("185h >" isNumeric1("185h"));System.out.println("-1 >" isNumeric1("-1"));Syst…

11.30_黑马Redis实战篇分布式锁

实战篇9 设立一个在jvm外的锁监视器&#xff0c;可以处理多线程的问题 实战篇10 获取锁的时候&#xff0c;要同时发生获取锁以及设置到期时间。 实战篇11 thinking&#xff1a;JAVA中的自动拆箱与装箱&#xff1f; 【Java基础】自动拆装箱_Elephant_King的博客-CSDN博客 TR…

MySql常用面试题

1 MySql, Oracle &#xff0c; Sql Service 的区别 Sql Service 只能在 Windows 上使用&#xff0c;而 MySql 和 Oracle 可以在其他系统上使用&#xff0c; 而且可以支持数 据库不同系统之间的移植 MySql 开源免费的&#xff0c; Sql Service 和 Oracle 要钱。 Oracle 支持…

owasp应用安全验证标准 ASVS 4.0.3

OWASP应用安全验证标准 |OWASP基金会 ASVS安全应用评估标准是一项社区驱动的工作&#xff0c;旨在建立一个安全要求和控制的框架&#xff0c;在设计、开发和测试现代网络应用程序 和网络服务时&#xff0c;定义所需要的功能和非功能性的安全控制措施。 《OWASP Top 10 2017》是…

python读取所有sheet内容到另一个文件中

实现效果&#xff1a; 将原excel中的步骤、预期效果列按回车拆成多行数据&#xff0c;其余字段值填充其他数据 实现结果&#xff1a; # This is a sample Python script.# Press ShiftF10 to execute it or replace it with your code. # Press Double Shift to search everyw…

施密特正交

描述 给出一个向量组原始基&#xff0c;通过施密特正交化、单位化&#xff0c;构造出标准正交基。 输入 本题有多组测试数据。每组测试数据在第一行给出两个正整数t&#xff0c;n&#xff0c;表示有t个n维向量。随后t行每行给出n个实数表示一个向量。 输出 每行输出一个向量…

min函数的栈(最小栈),剑指offer,力扣

目录 题目地址&#xff1a; 相同题目题解地址&#xff1a; 题目&#xff1a; 我们直接看题解吧&#xff1a; 解题方法&#xff1a; 审题目事例提示&#xff1a; 解题分析&#xff1a; 解题思路&#xff1a; 补充说明&#xff1a; 代码实现&#xff1a; 题目地址&#xff1a; L…

[javascrip] typeof和instanceof

typeof和instanceof的区别是&#xff1a;typeof的返回值是一个字符串&#xff0c;用来说明变量的数据类型&#xff1b;instanceof的返回值是布尔值&#xff0c;用于判断一个变量是否属于某个对象的实例。 instanceof instanceof 运算符&#xff1a;A instanceof B 检查 A的原…

防火墙规则保存及自定义链

目录 防火墙规则保存 备份工具 iptables services 自定义链 自定义链实现方式 删除自定义链 重命名自定义链 防火墙规则保存 命令&#xff1a;iptables -save 工具&#xff1a;iptables services [rootlocalhost ~]# iptables-save > /opt/iptables.bak #将文件保存…

二阶变系数线性微分方程

1、变量替换法 欧拉方程 是常数&#xff0c;是已知的函数。 二阶欧拉方程 (1) 当时&#xff0c;令,则 代入&#xff08;1&#xff09;中&#xff0c; .这样就把欧拉方程&#xff0c;化成了二阶常系数非齐次微分方程 当x<0时&#xff0c;令, 例题 解:令,则 代入上面的推…