vue_03路由

概念

Vue属于单页应用(SPA),即整个应用程序中只有一个html页面。

在单页应用中(SPA),由于只是更改DOM来模拟多页面,所以页面浏览历史记录的功能就丧失了。此时,就需要前端路由来实现浏览历史记录的功能。

添加路由

进入dos,切换目录到项目下

例如:项目目录为:D:\workspace\qd\demo04,则dos如下

输入命令

复制代码
yarn add vue-router

执行命令

复制代码
yarn list

或者

你还可以使用--pattern参数来过滤依赖项列表。例如,要查看包含"vue-router"的依赖项,可以运行以下命令:

复制代码
yarn list --pattern *vue-router*

配置路由

在src目录下创建router目录

在router目录下创建index.ts的文件名,用于配置路由

在index.ts文件中配置路由

js 复制代码
import {createRouter,createWebHistory,type RouteRecordRaw} from 'vue-router'
const routes:RouteRecordRaw[]=[
//    {
//     path:"/",
//     component:import("../components/HelloWorld.vue")
//    }
]
const router=createRouter({
    history:createWebHistory(),
    routes
})

export default router

在main.ts文件中使用路由

js 复制代码
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
import router from './router'
createApp(App).use(router).mount('#app')

常用控件

  • <router-link to="对应路由的path">显示的文本</router-link>
  • <router-view/>:用于指定组件显示的位置
vue 复制代码
<template>
	 <nav>
		<!-- 使用 router-link 组件来导航. to属性指定导航地址-->
	    <!-- <router-link to="/">Home</router-link> |
	    <router-link to="/about">About</router-link> -->
	  </nav>
	 <!-- 路由出口(路由匹配到的组件将渲染在这里) -->
	  <router-view/>
</template>

或者

vue 复制代码
  <template>
    <div class="app">
      <h2 class="title">Vue路由测试</h2>
      <!-- 导航区 -->
      <div class="navigate">
        <RouterLink to="/home" active-class="active">首页</RouterLink>
        <RouterLink to="/news" active-class="active">新闻</RouterLink>
        <RouterLink to="/about" active-class="active">关于</RouterLink>
      </div>
      <!-- 展示区 -->
      <div class="main-content">
        <RouterView></RouterView>
      </div>
    </div>
  </template>
  <script lang="ts" setup name="App">
    import {RouterLink,RouterView} from 'vue-router'  
  </script>

通过脚本进行跳转

vue 复制代码
<template>
  <div>
    <button @click="toLogin">跳转</button>
  </div>
</template>
<script setup lang="ts">
 
 import { useRouter } from 'vue-router';
 
 
 const router =useRouter();
 //按钮1路由跳转
 function toLogin(){
   router.push({path:'/indexLeft'})
 }
</script>
<style scoped>

</style>
相关推荐
白兰地空瓶1 小时前
🏒 前端 AI 应用实战:用 Vue3 + Coze,把宠物一键变成冰球运动员!
前端·vue.js·coze
Liu.7742 小时前
vue3使用vue3-print-nb打印
前端·javascript·vue.js
松涛和鸣3 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
dly_blog3 小时前
Vue 逻辑复用的多种方案对比!
前端·javascript·vue.js
万少3 小时前
HarmonyOS6 接入分享,原来也是三分钟的事情
前端·harmonyos
烛阴3 小时前
C# 正则表达式:量词与锚点——从“.*”到精确匹配
前端·正则表达式·c#
wyzqhhhh4 小时前
京东啊啊啊啊啊
开发语言·前端·javascript
JIngJaneIL4 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
q_19132846954 小时前
基于Springboot+MySQL+RuoYi的会议室预约管理系统
java·vue.js·spring boot·后端·mysql·若依·计算机毕业设计
想学后端的前端工程师4 小时前
【Java集合框架深度解析:从入门到精通-后端技术栈】
前端·javascript·vue.js