【路由組件】

完成Vue Router 安装后,就可以使用路由了,路由的基本使用步骤,首先定义路由组件,以便使用Vue Router控制路由组件展示与 切换,接着定义路由链接和路由视图,以便告知路由组件渲染到哪个位置,然后再项目中创建路由模块,最后导入并挂载路由模块。

接下来通过实际操作方式演示Vue Router使用方法。
1.定义路由组件

在src \components 目录下创建2个组件,分别为Home

组件和About组件,用于演示组件切换效果,文件名为Home.vue和About.vue

Home.vue文件代码如下:

csharp 复制代码
<template>
	<div class="home-container">
		<h3>Home组件</h3>
	</div>
</template>
<style scoped>
	.home-container{
		min-height:150px;
		background-color:#f2f2f2;
		padding:15px;
	}
<yle>

About.vue文件代码如下:

csharp 复制代码
<template>
	<div class="home-container">
		<h3>Home组件</h3>
	</div>
</template>	
<style scoped>
	.about-container{
		min-height:150px;
		background-color:#f2f2f2;
		padding:15px;
	}
<yle>

定义路由链接和路由视图

为了在页面中将路由对应的组件显示出来,还要在App组件中定义路由视图。路由视图标签定义,该标签会被渲染成当前路由对应组件,另外,为了方便在不同组件之间切换,可以通过标签定义路由链接,该标签的to属性表示链接地址,与路由匹配规则中的path属性对应。

在src\App.vue文件中定义路由视图以及Home组件和About组件路由链接,具体代码如下。

csharp 复制代码
<template>
	<div class="home-container">
		<h1>App根组件</h1>
		<router-link to="/home">首页</router-link>
		<router-link to="/about">关于</router-link>
		<hr>
		<router-view></router-view>
	</div>
</template>	
	<style scoped>
	.app-container{
		text-align:center;
		font-size:16px;
	}
	.app-container a {
		padding:10px;
		color:#000;
}
	.app-container a.routerr-link-active{
		color:#fff;
		background-color:#000;
}
<yle>

上述代码:第4行通过to属性定义Home组件链接地址为"/Home",与路由匹配规则中path属性值"home"对应,第7行代码使用标签渲染当前路由对应组件,19-22行代码用于激活路由链接设置高亮样式。

相关推荐
vipbic4 小时前
别再把“做个H5”挂嘴边了:这个词,官方压根就没有定义过
前端
ZC跨境爬虫5 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦5 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
开发者每周简报5 小时前
网海三部曲·无名宗师传
javascript·人工智能
喵个咪6 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
qq_2518364577 小时前
SpringBoot+Vue 共享电池柜管理系统 完整实现 前后端分离项目实战 完整代码
vue.js·spring boot·后端
摆烂大大王7 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao7 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
梦想的颜色7 小时前
TypeScript 完全指南(上):从零开始掌握类型系统
前端·typescript
之歆8 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6