vue3 vue-router的安装及配置 (一)

文章目录

  • 一、安装
  • 二、Vue Router配置
    • 2.1 vue-router两种引入方式的区别
    • 2.2 不同的历史模式
  • 三、router-link
  • 四、router-view

Vue Router作用:在应用程序中实现优雅的导航和路由管理。

一、安装

注意:vue3安装的是vue-router@4,vue2安装的是vue-router@3,这里我们讲解的是vue3,所以应当安装其4版本。

npm install vue-router@4

二、Vue Router配置

在下面的代码中,我们首先创建router文件引入createRouter 和 createWebHistory 函数。然后定义了路由规则并创建了一个router实例。最后我们在main.ts文件中使用app.use(router)将router实例挂载到Vue应用程序中。

//router/index.ts
import { createRouter, createWebHistory, RouteRecordRaw } from "vue-router";const routes: Array<RouteRecordRaw> = [{ path: "/", component: () => import("@/views/home/index.vue") },{ path: "/about", component: () => import("@/views/about/index.vue") },
];export const router = createRouter({history: createWebHistory(),routes,
});//main.ts
import { createApp } from 'vue'
import { router } from "@/router/index";
const app = createApp(App)
app.use(router)
app.mount('#app')

2.1 vue-router两种引入方式的区别

  • 1、直接组件引入
import { createRouter, createWebHistory, RouteRecordRaw } from "vue-router";
import home from "@/views/home/index.vue";
import about from "@/views/about/index.vue";const routes: Array<RouteRecordRaw> = [{ path: "/", component: home },{ path: "/about", component: about },
];export const router = createRouter({history: createWebHistory(),routes,
});

直接把组件引入进来,不关路径访问或不访问,都把组件引用进来。一次性加载这么多内容,加载会很慢。而且打包时这种方式会这直接将引入的组件一起打进一个js文件中,造成性能问题。

  • 2、异步加载/懒加载
import { createRouter, createWebHistory, RouteRecordRaw } from "vue-router";const routes: Array<RouteRecordRaw> = [{ path: "/", component: () => import("@/views/home/index.vue") },{ path: "/about", component: () => import("@/views/about/index.vue") },
];export const router = createRouter({history: createWebHistory(),routes,
});

访问了才加载,没有访问就不加载,项目中推荐使用此方式

2.2 不同的历史模式

  • Hash 模式
    • 后面有个#
    • 不会触发重载页面:随意打上 # + 任意字符并回车,浏览器会认为你想要跳转到当前页面某个位置
    • SEO差:google spider(谷歌的爬虫)会忽视掉 # 后面的内容

hash模式 原理是通过监听 hashchange 事件来实现路由的切换

window.addEventListener('hashchange', function(event){ // console.log(event)
})
  • history模式
    • 更友好的URL
    • 无刷新页面切换
    • 更好的SEO
    • 需要服务器配置要求
window.addEventListener('popstate', function(event) {console.log(event);
});

三、router-link

该标签是一个vue-router中已经内置的组件,它会被渲染成一个<a>标签,但比<a>标签更好的是可以在不重新加载页面的情况下更改 URL

<!--使用 router-link 组件进行导航 -->
<!--通过传递 `to` 来指定链接 -->
<!--`<router-link>` 将呈现一个带有正确 `href` 属性的 `<a>` 标签-->
<router-link to="/home">Go to Home</router-link>
<router-link to="/about">Go to About</router-link>

在这里插入图片描述

上面to属性除了字符串的写法还可以写成对象的形式:

<router-link :to="{ path: '/home' }">home</router-link>
<router-link :to="{ name: 'about' }">about</router-link>

四、router-view

router-view 将显示与 url 对应的组件。你可以把它放在任何地方,以适应你的布局

<template><router-link :to="{ path: '/home' }">home</router-link><router-link :to="{ name: 'about' }">about</router-link><router-view></router-view>
</template>

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

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

相关文章

大学里面转专业介绍

目录 个人情况转专业过程中的经验分享转专业后的学习建议和心态调整转专业后的时间平衡 个人情况 信息科学与工程学院计算机科学与技术专业2019级本科生&#xff0c;曾从物理与微电子科学学院后转入信息科学与技术学院。学习成绩连续三年专业前10% 项目&#xff1a;爬虫项目、…

python-单词本|通讯录

编写程序&#xff0c;生词本。 def sayHello():print("" * 20 \n 欢迎使用生词本\n 1.查看生词本\n 2.背单词\n 3.添加新单词\n 4.删除单词\n 5.清空生词本\n 6.退出生词本\n * 20 \n)def addW(data):word input("请输入新单词&#xff1a;")trans i…

ai学习之快捷键介绍

ai2021学习之快捷键介绍 F 全屏Ctr Y &#xff0c;可以在去色和全色中切换。Shift O 画板工具CtrlALTY 将矢量图转为位图。Ctrl R 可以显示标尺&#xff0c; CTRL冒号&#xff08;&#xff1a;&#xff1b;&#xff09; 隐藏参考线智能参考线CTRLshirtz 撤回撤回的撤回 Ai是一个…

python flask Jinja2模板学习

分类很好的一篇文章 Jinja2模板语法 Jinja2里常见的三种定界符&#xff1a; (1) 语句 {% ... %}(2) 表达式 {{ ... }}(3) 注释 {# ... #} {%set adazhaung%} 语句设置变量{{a}} 表达式{% if 2>1 %}控制语句以{%endif%}结尾 Jinja2支持使用“.”获取变量的属…

Python小案例:99乘法表打印

99乘法表的打印 分析&#xff1a; 1、需要利用两次循环进行控制循环次数 2、通过print参数进行控制打印样式 代码部分 # 外循环实现层级 for i in range(1,10):# 内循环控制计算for j in range(1,i1):# 利用print函数结尾end参数控制打印print(f"{j}*{i}{j*i}",e…

FPGA时序分析与时序约束(一)

一、为什么要进行时序分析和时序约束 PCB通过导线将具有相关电气特性的信号相连接&#xff0c;这些电气信号在PCB上进行走线传输时会产生一定的传播延时。 而FPGA内部也有着非常丰富的可配置的布线资源&#xff0c;能够让位于不同位置的逻辑资源块、时钟处理单元、BLOCK RAM、D…

【未解决】huggingface模型文件下载地址为什么会变?

问题描述 上次我们已经分析了huggingface加载模型时候的文件目录应该是怎么样的&#xff1f;&#xff08;感兴趣的可以主页搜索“【经验分享】huggingface模型加载过程下载到cache文件目录具体是怎么组织的&#xff1f;以及都会有什么文件目录&#xff0c;每个文件目录是什么&a…

翻译: 生成式人工智能的工作原理How Generative AI works

ChatGPT 和 Bard 等系统生成文本的能力几乎像魔法一样。它们确实代表了 AI 技术的一大步进。但是文本生成到底是如何工作的呢&#xff1f;在这个视频中&#xff0c;我们将看看生成式 AI 技术的底层原理&#xff0c;这将帮助你理解你可以如何使用它&#xff0c;以及何时可能不想…

【开源】基于JAVA的考研专业课程管理系统

项目编号&#xff1a; S 035 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S035&#xff0c;文末获取源码。} 项目编号&#xff1a;S035&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 考研高校模块2.3 高…

免费的SEO外链发布工具,提升排名的利器

互联网已经成为信息传播和商业发展的重要平台。而对于拥有网站的个人、企业来说&#xff0c;如何让自己的网站在搜索引擎中脱颖而出&#xff1f;SEO&#xff08;Search Engine Optimization&#xff09;作为提高网站在搜索引擎中排名的关键手段. 什么是SEO外链&#xff1f; S…

【STM32入门】3.OLED屏幕

1.OLED引脚 OLED屏幕的接线按图所示&#xff0c;本例中用的是4管脚OLED屏幕 2.驱动程序 配套的驱动程序是“OLED.c"&#xff0c;主要由以下函数构成&#xff1a;1、初始化&#xff1b;2、清屏&#xff1b;3、显示字符&#xff1b;4、显示字符串&#xff1b;5、显示数字…

使用激光雷达(LiDAR)和相机进行3D物体跟踪

使用相机和激光雷达进行时间到碰撞&#xff08;TTC&#xff09;计算 在我的先前文章中&#xff0c;我介绍了通过检测关键点和匹配描述符进行2D特征跟踪的主题。在本文中&#xff0c;我将利用这些文章中的概念&#xff0c;以及更多的内容&#xff0c;开发一个软件流水线&#xf…

STM32串口通信初探:使用HAL库实现基本功能

在本文中&#xff0c;我们将探索如何使用STM32的HAL库来实现串口通信的基本功能。串口通信是一种常见的外设通信方式&#xff0c;用于在微控制器和其他外部设备之间进行数据传输。在STM32系列微控制器中&#xff0c;HAL库提供了简单且灵活的方法来实现串口通信。我们将重点讨论…

深入理解强化学习——马尔可夫决策过程:蒙特卡洛方法-[代码实现]

分类目录&#xff1a;《深入理解强化学习》总目录 在文章《深入理解强化学习——马尔可夫决策过程&#xff1a;蒙特卡洛方法-[基础知识]》中我们介绍了利用蒙特卡洛方法计算马尔可夫决策过程价值的方法&#xff0c;本文将用代码定义一个采样函数。采样函数需要遵守状态转移矩阵…

使用栈解决括号匹配问题(详解)

项目结构 项目头文件的代码或截图 头文件代码 #ifndef LINKSTACK_H #define LINKSTACK_H #include <stdio.h> #include <stdlib.h> // 链式栈的节点 typedef struct LINKNODE {struct LINKNODE* next; }LinkNode; // 链式栈 typedef struct LINKSTACK {LinkNode h…

【Java 基础】19 多线程基础

文章目录 进程和线程进程&#xff08;Process&#xff09;线程&#xff08;Thread&#xff09; 线程的创建1&#xff09;继承 Thread 类2&#xff09;实现 Runnable 接口3&#xff09;使用 Lambda 表达式4&#xff09;总结 线程的状态状态的分类状态间转换 多线程是一种 同时执…

6、原型模式(Prototype Pattern,不常用)

原型模式指通过调用原型实例的Clone方法或其他手段来创建对象。 原型模式属于创建型设计模式&#xff0c;它以当前对象为原型&#xff08;蓝本&#xff09;来创建另一个新的对象&#xff0c;而无须知道创建的细节。原型模式在Java中通常使用Clone技术实现&#xff0c;在JavaSc…

SpringBoot系列之集成Jedis教程

SpringBoot系列之集成Jedis教程&#xff0c;Jedis是老牌的redis客户端框架&#xff0c;提供了比较齐全的redis使用命令&#xff0c;是一款开源的Java 客户端框架&#xff0c;本文使用Jedis3.1.0加上Springboot2.0&#xff0c;配合spring-boot-starter-data-redis使用&#xff0…

基恩士软件的基本操作(六,KV脚本的使用)

目录 什么是KV脚本&#xff1f; KV脚本有什么用&#xff1f; 怎么使用KV脚本&#xff08;脚本不能与梯形图并联使用&#xff09;&#xff1f; 插入框脚本&#xff08;CtrlB&#xff09; 插入域脚本&#xff08;CtrlR&#xff09; 区别 脚本语句&#xff08;.T是字符串类…

【C进阶】C程序是怎么运作的呢?-- 程序环境和预处理(上)

前言&#xff1a; 由于c语言的程序编译链接的这块知识点不清楚&#xff0c;回来复习一遍&#xff0c;以便于好理解c知识&#xff0c;我会尽快更新下一篇文章。 目录 1.程序的翻译环境和执行环境 2.翻译环境&#xff08;编译链接&#xff09; 编译&#xff08;编译器&#xf…