场景模拟:基础路由配置

引入

javascript 复制代码
import { createRouter, createWebHashHistory } from 'vue-router';

路由规则

javascript 复制代码
const routes = [
    {
        path: '/',
        name: 'main',
        component: () => import('@/views/Main.vue')
    }
]
  • routes是一个包含多个路由对象的数组

  • 每个路由对象至少包含两个属性:

    • path 是指定的路径
    • component 是该路径下对应的组件。

创建路由实例

ini 复制代码
const router = createRouter({
  // 设置路由模式
  history: createWebHashHistory(),
  routes,
});
  • createRouter():创建路由实例,接收一个配置对象

    • history:指定路由的模式
    • routes:一个数组,包含了多个路由对象。
  • createWebHashHistory:创建一个基于浏览器URL的hash模式

    • 在URL中使用#分隔实际路径http://example.com/#/about
    • 服务器端无需任何配置即可正常生效
    • 缺点:url不太美观(createWebHistory更美观,但需要服务器端进行配置)

导出路由实例

arduino 复制代码
export default router;

注册路由

两种情况:

  • 在main.js中注册路由,在组件中可以直接使用 this.$routerthis.$route

    • this.$router:导航到不同页面:

      this.$router.push({ name: 'main' })

    • this.$route:获取当前路由信息:

      this.$route.path 或 this.$route.name

  • 未在main.js中注册,在需要使用路由实例的文件中手动引入 router

注册:

js 复制代码
// src/main.js
import { createApp } from 'vue';
import App from './App.vue';
import router from './router'; // 引入路由实例
const app = createApp(App);
app.use(router); // 使用路由实例
app.mount('#app');

使用:

vue 复制代码
<script>
...
​
  this.$router.push({ name: 'main' }); // 直接使用 this.$router
    
...
</script>

未注册:

js 复制代码
<script>
import router from '../router'; // 手动引入路由实例
export default {
  methods: {
    navigateToMain() {
      router.push({ name: 'main' }); // 使用手动引入的 router
    }
  }
}
</script>

组件中使用路由

<router-view> 组件中的占位符,显示的内容根据当前路由决定

js 复制代码
<script setup></script>

<template>
    <!--占位符-->  
  <router-view></router-view>
</template>

<style scoped></style>

补充:命名视图

在一个页面中,使用多个占位符来分别显示不同的组件内容,可以使用命名视图(Named Views)。

命名视图允许你在同一个路由中定义多个<router-view>,每个视图可以显示不同的组件。

组件配置

js 复制代码
<script setup>
</script>
<template>
  <router-view name="header"></router-view>
  <router-view name="main"></router-view>
</template>
<style scoped>
</style>

路由配置

js 复制代码
...
import HeaderComponent from '@/components/HeaderComponent.vue'
import MainComponent from '@/components/MainComponent.vue'
​
const routes = [
  {
    path: '/',
    name: 'main',
    components: {
      header: HeaderComponent,
      main: MainComponent
    }
  }
];
相关推荐
kyriewen1114 分钟前
异步编程:从“回调地狱”到“async/await”的救赎之路
开发语言·前端·javascript·chrome·typescript·ecmascript·html5
Old Uncle Tom15 分钟前
Markdown Viewer 再升级
前端
Luna-player18 分钟前
Vue3中使用vue-awesome-swiper
前端·vue.js·arcgis
SuperEugene23 分钟前
Vue3 Pinia 状态管理规范:状态拆分、Actions 写法、持久化实战,避坑状态污染|状态管理与路由规范篇
前端·javascript·vue.js·前端框架·pinia
black方块cxy23 分钟前
实现一个输入框多个ip以逗号分隔最多20组,且ip不能重复
java·服务器·前端
@PHARAOH37 分钟前
WHAT - AI 时代下的候选人
大数据·前端·人工智能
竹林8181 小时前
从零到一:我在Solana NFT铸造前端中搞定@solana/web3.js连接与交易
前端·javascript
猪八宅百炼成仙1 小时前
不用点击也能预览图片:Element UI ImageViewer 命令式调用方案
前端
尘世中一位迷途小书童1 小时前
前端工程化基石:package.json 40+ 字段逐一拆解
前端·javascript·架构
OpenTiny社区2 小时前
WebMCP + WebSkills:企业级智能化页面操控方案,兼顾隐私安全与高效落地!
前端·ai编程·mcp