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

相关文章

Jquery 实现表单提交按钮变灰,防止多次点击提交重复数据

表单提交时候我们应该控制提交按钮,不能点击多次进行数据的重复提交。要不然就会有冗余的重复的数据在系统中,造成系统出现数据垃圾。jQuery很简单的就可以实现对表单提交按钮控制,下面就是相关的例子和代码。 <form action="${pageContext.servletContext.contextPath}/XXX/###" method="post" id="messag

maven学习系列——(二)maven的安装和一些基本的配置

这一篇主要会总结maven在window上的安装,以及Eclipse安装maven插件。 会整理和贴出具体的安装步骤等! 配置大概会整理一下,方便自己查看和使用! Maven 的使用在Windows上使用比较多,一般的开发都是在Windows上;Linux上的使用相对比较少,不过会总结Windows和Linux系统两种安装方式。 首先会介绍在Windows和Eclipse安装Maven,L

OpenResty 最佳实践学习--安装和helloworld(1)

一:简介 OpenResty® 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。 OpenResty® 通过汇聚各种设计精良的 Nginx 模块(主要由 OpenResty 团队自主开发),从而将 Nginx 有效地变成一个强

MySQL字段存储的内容是不区分大小写的,你知道吗?

做一个积极的人 编码、改bug、提升自己 我有一个乐园,面向编程,春暖花开! 文章目录 00 简单回顾01 一个例子02 解决方案03 总结04 参考资料 00 简单回顾 之前写过一篇关于mysql 对表大小写敏感的问题,其实在mysql中字段存储的内容是不区分大小写的,本篇进行简单的总结。 想回顾一下: MySQL在Linux下数据库名、表名、列名、别名大小写规则

MySQL存储的字段是不区分大小写的,你知道吗?

点击上方Java编程技术乐园,轻松关注! 及时获取有趣有料的技术文章 做一个积极的人编码、改bug、提升自己 我有一个乐园,面向编程,春暖花开! 00 简单回顾 之前写过一篇关于mysql 对表大小写敏感的问题(你有遇到过MySQL因大小写敏感导致的问题吗),其实在mysql中字段存储的内容是不区分大小写的,本篇进行简单的总结。 想回顾一下: MySQL在Linux下数据库名、表名、列名、别名大

2019年长沙前端技术分享大会圆满成功

做一个积极的人 编码、改bug、提升自己 我有一个乐园,面向编程,春暖花开! 本文首发: 唐胡子俱乐部,授权发布! 摘要 长沙百名互联网前端程序员齐聚长沙互联网活动基地(唐胡子俱乐部)。 主办单位:唐胡子俱乐部 支持单位:芒果TV,拓维,湘邮,58到家,御泥坊,兴盛优选,中软国际,长海科技,长沙联通 时 间:2019年5月19日 ----------------------

Kali:系统安装之后进行所需配置

apt设置源 由于官网的源需要墙或者想使用国内的源,可以修改source.list vi /etc/source.list 打开文件并修改为其他可用的源地址,以下可供参考 deb http://ftp.sjtu.edu.cn/debian wheezy main non-free contribdeb-src http://ftp.sjtu.edu.cn/debian wheezy ma

Jekyll 解决Jekyll server本地预览文章not found的问题

layout: post tags: [Jekyll] comments: true 执行Jekyll本地浏览器预览指令 bundle exec jekyll serve 进入浏览器输入127.0.0.1:4000,可以正常浏览首页,但是点击文章链接,则会显示404页面,查看控制台显示错误的log,如下: PS D:\work\github\test\_site> bundle e

测试服务搭建之centos7下安装java

一 安装Java 1 创建普通用户 useradd userNameTest passwd userNameTest 提示输入密码:【输入wujian的密码】 user:userNameTest group:root passwd:123456789   2 给“userNameTest”分配root权限 vi /etc/sudoers 在文件中找到 # %wheel ALL=(

vue3显示element-plus所有icon

效果 代码 <template><div style="display: flex;flex-wrap: wrap"><component :is="name" style="width: 2rem; margin-left: 2rem" v-for="(name,index) in icons" :index="index" :key="index"></component></div>