Vue3-黑马(十四)

news2025/1/19 17:06:00

目录:

(1)vue3-进阶-router-令牌-前端路由

(2)vue3-进阶-router-令牌-前端路由

(3)vue3-进阶-pinia1

(4)vue3-进阶-pinia2


(1)vue3-进阶-router-令牌-前端路由

下面我们来看tocken的第二个用途, 作为前端路由的跳转依据

我们想要实现这样一个,当没有登录后是不能访问主页的信息,没有登录要跳到登录页面,我们在跳转主页之前做一个检查判断是否含有tocken,有tocken放行,没有tocken调回登录页面

在路由中添加代码,在每次跳转路由前进行执行这个函数:beforeEach

访问主页: 

 

 调回登录页面

 我们vue的页面单页面程序,不管你的组件有多少,它最外层的html页面只要一个index.html:

 

其他组件在这个页面的中的title显示时一样的。

用一个函数afterEach用解决页面标题一样的问题 ,路由跳转之后执行

 

(2)vue3-进阶-router-令牌-前端路由

tocken的另外一个作用,是后端Api的访问依据,前端访问后端,需要前端的请求携带一个tocken,这个tocken用于身份的校验

 

前端访问请求需要携带tocken ,axios在请求拦截器中添加携带tocken

 导入当时存入的tocken变量

 

 发现登录获取菜单的请求携带了一个请求头,把获取的tocken请求发送给服务器,经过拦截器验证,验证成功才会返回正确信息

 

(3)vue3-进阶-pinia1

这样一个需求在登录成功后,在右上角不仅显示用户名还有真实姓名和性别,用户的基本信息 

在菜单一种可以修改当前登录的用户信息,更新数据库,修改成功后在主页组件右上角也要同时更新,但是你会发现这是两个组件,外面那个主页组件是不会变化的,这是遇到的问题,怎么解决呢?需要一个新的技术pinia,可以针对多个组件之间实现数据的共享,这个数据是响应式的数据 

 那么象使用LocalStorage不行吗?把菜单数据存入localStorage,因为登录成功后把数据存入localStorage后进行页面的跳转,跳转后进入主页面,当页面加载时可以在从LocalStorage中获取,但是修改页面信息没有实现页面跳转所以是不行的,不会主动触发读取locaStorage,除非加一个按钮触发代码来读取更新后的信息

pinia就想vuex一样实现不同组件的数据共享问题

首先安装

 

在main.ts引入pinia

 创建文件夹:存放数据共享的数据

 先定义一个固定的共享数据:

在主页引入:使用这个共享数据

 

 

P1组件使用这个共享数据

 

使用Mounted函数,通过Object.assign进行对象的赋值,因为上面的表单对象已经跟dto对象绑定了,直接把共享数据跟dto对象进行赋值 

为什么共享数据userInfo直接跟表单进行绑定呢?因为如果进行了绑定,当在这个页面修改时,右上角就会立马改动,用不到下方的确定按钮啦

 

 在P1这个组件中更新数据保存到共享数据中

修改一下内容: 

 点击确定:

 

 (4)vue3-进阶-pinia2

 useRequest一般用到组件里

 

 

 

 我们用的是vue的component组合式API,见不到this

在主页面:调用这个方法

 

 在P1组件点击确定的按钮:调用这个方法更新数据

 

 点击确定,更新了数据库,主页组件也同时更新

 

 

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

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

相关文章

vite3+vue3 项目打包优化

现在很多小伙伴都已经使用 Vite Vue3 开发项目了,如果你是 “前端架构师” 或者是 “团队核心” 的话,不得不可考虑的一个问题就是性能优化。 说到前端性能优化,个人认为主要有两个方面: 减少文件的体积,体积小了加载…

SIEM日志管理解决方案

如果管理员想知道管理的网络中发生了什么,以便洞察潜在的威胁并在它们变成攻击之前阻止它们,那么管理员需要查看网络日志。企业网络中的设备如路由器、交换机、防火墙、服务器,业务运行的应用程序,如数据库和web服务器等。所有这些…

SpringBoot核心运行原理解析之-------@EnableAutoConfiguration

核心运行原理 我们通常在使用Spring Boot时,只需要引入对应的starters,Spring Boot启动时变回自动加载相关依赖,配置相应的初始化参数,以最快捷,简单的形式对第三方软件进行集成,这边是Spring Boot的自动配置功能。下…

【服务器数据恢复】EMC NAS中的虚拟机数据恢复案例

服务器数据恢复环境: 北京某公司的EMC NAS,总共有3个节点,每个节点配置12块STAT硬盘。 NAS中存放有vmware虚拟机(WEB 服务器)和视频文件。 虚拟机通过NFS协议共享到ESX主机,视频文件通过CIFS协议共享给虚拟…

Scala字符串常用函数

Scala字符串常用函数 1. 子字符串-substring2. 字符串切分-split3. 去掉首尾空格-trim4. 与数值之间的转换完整代码参考链接 Scala中的字符串为String类型,其实就是Java中的java.lang.String。其常用函数如下: 1. 子字符串-substring substring()方法返…

AUTOSAR NvM 同步机制

一、部分 NvM API 解释 (1)Std_ReturnType NvM_ReadBlock(NvM_BlockIdType BlockId,void* NvM_DstPtr) 把Nv Block中的数据copy到NvM_DstPtr指向的RAM中,NvM_DstPtr可以是临时RAM,也可以是永久RAM(永久RAM即配置工具…

自动化、智能、机器人-2023-

文明:农业、工业、信息、智能,以目前认知的四个阶段。 农业文明到工业文明:机械自动化 工业文明到信息文明:电气自动化 信息文明到智能文明:数据自动化 这些时代典型的机器人: 机械自动化 电气自动化 数…

Mini_Web开发

文章目录 服务器开发回顾面向对象服务端客户端(浏览器)请求数据处理判断不同的请求路径,返回不同的数据给前端 单独封装方法不同请求路径处理的方法再次拆分业务封装JSON数据处理 Mini_Web开发导入数据使用Python操作数据库使用pymysql模块日…

瑞吉外卖 - 编辑员工信息功能(9)

某马瑞吉外卖单体架构项目完整开发文档,基于 Spring Boot 2.7.11 JDK 11。预计 5 月 20 日前更新完成,有需要的胖友记得一键三连,关注主页 “瑞吉外卖” 专栏获取最新文章。 相关资料:https://pan.baidu.com/s/1rO1Vytcp67mcw-PD…

238:vue+openlayers绘制扩展,弓形、曲线、扇形、双箭头、进攻方向...

第238个 点击查看专栏目录 本示例的目的是介绍演示如何在vue+openlayers中利用ol-plot插件进行绘制图形扩展,可以绘制弓形、弧形、标志旗、战斗进攻图形等等。 直接复制下面的 vue+openlayers源代码,操作2分钟即可运行实现效果; 注意如果OpenStreetMap无法加载,请加载其他…

win11 下部署Vicuna-7B,Vicuna-13B模型,

运行Vicuna-7B需要RAM>30GB或者14GB的显存 运行Vicuna-13B需要RAM>60GB或者28GB的显存 如果没有上面的硬件配置请绕行了,我笔记本有64G内存,两个都跑跑看,使用python3.9,当时转换13b时一直崩溃后来发现是没有设定虚拟内存&…

Linux指令 快捷键

热键 上一次我们说到了linux的基本指令,这次我们先说一下热键 TAB TAB键在linux中有什么作用呢?? 在Linux中,假设我们想要输入的指令忘记了,我们可以TAB两下,帮我们补全命令或者假如命令太多&#xff0…

C++基础STL-set容器

set容器介绍: set译为集合,集合是按照特定顺序存储唯一元素的容器。在集合中,元素的值也标识它(值本身就是键,类型为T),并且每个值必须是唯一的。集合中元素的值在容器中一次就不能修改(元素总是const),但可…

python学习环境准备

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言本专栏文章旨在记录《Python编程从入门到实践》一书的学习笔记。 一、编程环境二、使用步骤1.修改默认python版本2.终端退出python解释器3.编写.py文件4.运行.p…

【Linux是如何发送网络包的?】

网络模型 为了使得多种设备能通过网络相互通信,和为了解决各种不同设备在网络互联中的兼容性问题,国际标准化组织制定了开放式系统互联通信参考模型(Open System Interconnection Reference Model),也就是 OSI 网络模…

【工作中掌握10个就够了!!!】Linux中的10个最常见命令+vim三个基本操作

欢迎观看我的博客,如有问题交流,欢迎评论区留言,一定尽快回复!(大家可以去看我的专栏,是所有文章的目录)   文章字体风格: 红色文字表示:重难点★✔ 蓝色文字表示&#…

【macOS自带VNC远程】——Windows在外远程桌面控制macOS

文章目录 前言1.测试局域网内远程控制1.1 macOS打开屏幕共享1.2 测试局域网内VNC远程控制 2. 测试公网远程控制2.1 macOS安装配置cpolar内网穿透2.2 创建tcp隧道,指向5900端口 3. 测试公网远程控制4. 配置公网固定TCP地址4.1 保留固定TCP地址4.2 配置固定TCP端口地址…

Java | 一分钟掌握定时任务 | 4 - 多线程的Timer

作者:Mars酱 声明:本文章由Mars酱原创,部分内容来源于网络,如有疑问请联系本人。 转载:欢迎转载,转载前先请联系我! 前言 JDK自带的Timer是无法做到多任务并发的,那么我们怎么处理多…

如何编写一份优质软件测试工程师简历的范文【建议收臧】

很多刚转行软件测试的小伙伴是不是不知道怎么写好一份优质的软件测试工程师的简历。今天呢,就给大家分享一下一个优质软件测试工程师简历的范文。记得收藏起来哦。 下面的案例:2-3年的软件测试工程的简历 姓 名:XXX 学历&#xff1a…

Zabbix“专家坐诊”第191期问答汇总

问题一 Q:snmp监控服务器风扇、温度等硬件信息需要要mib库吗? A:官网有相关的mib库可查,一般同大型号通用,直接去官方下就行。 问题二 Q:zabbix用的postgresqltimescaledb备份这个数据库的时候不想包含历…