【路由組件】

完成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行代码用于激活路由链接设置高亮样式。

相关推荐
鹅天帝4 分钟前
20260407网安学习日志——序列化漏洞
前端·学习·web安全·网络安全·xss
早點睡3904 分钟前
ReactNative项目OpenHarmony三方库集成实战:react-native-fs
javascript·react native·react.js
CHANG_THE_WORLD8 分钟前
演示宽度数组解析
linux·服务器·前端
天渺工作室8 分钟前
Nuxt导航网站免费模板,用Nuxt复刻OneNav资源导航站
前端·nuxt·资源导航模板
cch89189 分钟前
PHP vs Vue.js:后端与前端的终极对比
前端·vue.js·php
yuhaiqiang9 分钟前
【珍藏干货】累计阅读破百万:我如何靠“标题公式”把冷门技术写出爆款的?
前端·后端·程序员
lxh011310 分钟前
蜗牛排序题解
javascript·算法
一只小阿乐17 分钟前
react 中的Zustand的store使用
前端·javascript·react.js·zustand
我命由我1234517 分钟前
Vue3 开发中,字符串中的 <br\> 标签被直接当作文本显示出来了,而不是被解析为 HTML 换行标签
开发语言·前端·javascript·vue.js·html·ecmascript·html5
亿元程序员34 分钟前
Cocos4开源都快半年了,还有不会用官方MCP的?安排!
前端