Vue3---router(安装、路由跳转、路由守卫、本地存储)

本文主要是介绍Vue3---router(安装、路由跳转、路由守卫、本地存储),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Vue3—router(安装、路由跳转、路由守卫、本地存储)

目录

  • Vue3---router(安装、路由跳转、路由守卫、本地存储)
    • 基础使用
      • 安装
      • 创建路由
    • 路由跳转
      • 无参跳转
        • js写法
        • html写法
      • 有参跳转
        • query
        • params
    • 路由守卫
    • 额外:本地存储
      • sessionStorage
      • localStorage
      • cookie
        • 基础用法
        • 示例

基础使用

安装

npm install vue-router@4

创建路由

src/router/index.js,没有则新建

import {createRouter, createWebHistory, createWebHashHistory} from "vue-router";// 引入自定义的组件
import HelloWorld from "../components/HelloWorld.vue";
import Aboutview from "../views/AboutView.vue";const routes = [{path: '/', name: 'home', component: HelloWorld},{path: '/about', name: 'about', component: Aboutview},
]const router = createRouter({routes,history:createWebHistory()
})export default router
  • createWebHistory:History模式创建路由
  • createWebHashHistory:Hash模式创建路由
// main.js
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
import router from "./router/index.js";createApp(App).use(router).mount('#app')
  • createApp(App).use(router).mount('#app')是链式调用写法

路由跳转

无参跳转

js写法
<template><div class="card"><router-link to="/about"><button>点我跳转到About组件</button></router-link></div>
</template>
html写法
<script setup>
import {useRouter} from "vue-router";
const router = useRouter()function toAbout() {router.push('/about')
}</script><template><div class="card"><button @click="toAbout">点我跳转到About组件</button></div>
</template>

有参跳转

query
  • 有参跳转的to需要在前面加上:,这样才能被vue识别为对象
<script setup>
import {useRouter} from "vue-router";
const router = useRouter()function toAbout() {router.push({name:'about',query:{id:1}})
}</script><template><div class="card">// js写法<button @click="toAbout">点我跳转到About组件</button>// html写法<router-link :to="{name:'about',query:{id:1}}"><button>我也能跳转About组件</button></router-link></div>
</template>

其他路由取出参数

  • 注意这里导入的是useRoute不是useRouter
// about.vue
<script setup>
import {useRoute} from "vue-router";const router = useRoute()
const id = router.query.id
</script><template>
<h1>{{ id }}</h1>
</template>
params
// src/router/index.js
import {createRouter, createWebHistory} from "vue-router";import Aboutview from "../views/AboutView.vue";const routes = [// 在参数前面加上':'{path: '/about/:id', name: 'about', component: Aboutview},
]const router = createRouter({routes,history:createWebHistory()
})export default router
<script setup>
import {useRouter} from "vue-router";
const router = useRouter()function toAbout() {router.push({name:'about',params:{id:1}})
}</script><template><div class="card">// js写法<button @click="toAbout">点我跳转到About组件</button>// html写法<router-link :to="{name:'about',params:{id:1}}"><button>我也能跳转About组件</button></router-link></div>
</template>

两者在浏览器url中的区别:

  • queryhttp://localhost:5173/about?id=1
  • paramshttp://localhost:5173/about/1

路由守卫

简单示例:

// src/router/index.js
import {createRouter, createWebHistory} from "vue-router";const routes = [...]
const router = createRouter({...})// 上面是注册路由的代码
router.beforeEach((to, from) => {// 当访问路由时没有携带token会直接alert 全局生效if (!localStorage.getItem('token')){alert('没有携带token')}
})
export default router
  • 此时访问任意路由都会弹出警告

image-20240508152213673

  • 携带token后便能正常访问

image-20240508152303687

额外:本地存储

sessionStorage

// 添加
sessionStorage.setItem('name', '张三')
// 获取
sessionStorage.getItem('name')
// 删除
sessionStorage.removeItem('name')
// 清除全部
sessionStorage.clear()

localStorage

// 添加
localStorage.setItem('name', '张三')
// 获取
localStorage.getItem('name')
// 删除
localStorage.removeItem('name')
// 清除全部
localStorage.clear()

cookie

使用cookie需要安装:

npm install vue-cookies
基础用法

注册

// main.js
import { createApp } from 'vue'
import App from './App.vue'
import VueCookies from 'vue-cookies';createApp(App).use(VueCookies).mount('#app')

增删查

<script setup>
import {inject} from "vue";const $cookies = inject('$cookies')// 添加
$cookies.set("name", '陈五','1h')
// 查询
$cookies.get("name", '陈五','1h')
// 删除
$cookies.remove("name", '陈五','1h')

inject 用于在子组件中从父组件或根组件中注入已经创建的实例,如果不想使用也可以直接引入 VueCookies实例

<script setup>
import VueCookies from "vue-cookies";const $cookies = VueCookies
// 添加
$cookies.set("name", '陈五','1h')
</script>
示例

main.js引入VueCookies并use

// main.js
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
import router from "./router/index.js";
import VueCookies from 'vue-cookies';createApp(App).use(VueCookies).use(router).mount('#app')

存入cookie并跳转到about组件

<script setup>
import {useRouter} from "vue-router";
import {inject} from "vue";
import VueCookies from "vue-cookies";const router = useRouter()
const $cookies = inject('$cookies');function setToken() {// 添加$cookies.set("name", '陈五','1h')router.push('about')
}
</script><template><div class="card"><button @click="setToken">点我跳转到About组件</button></div>
</template>

取出cookie并渲染到模版

<script setup>
import VueCookies from 'vue-cookies'
import {inject} from "vue";const $cookies = inject('$cookies');
const name = $cookies.get('name')</script><template>
<h1>{{ name }}</h1>
</template>
card"><button @click="setToken">点我跳转到About组件</button></div>
</template>

取出cookie并渲染到模版

<script setup>
import VueCookies from 'vue-cookies'
import {inject} from "vue";const $cookies = inject('$cookies');
const name = $cookies.get('name')</script><template>
<h1>{{ name }}</h1>
</template>

这篇关于Vue3---router(安装、路由跳转、路由守卫、本地存储)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973579

相关文章

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框