vite中自动根据约定目录生成路由配置

概述

工程化项目中,有时候可能一个项目会有多个路由页面,每次新加路由页面都需要去修改路由配置文件,如果我们可以在约定的目录情况下,自动根据目录结构生成对应的路由结构,就不用每次路由新增的时候都去改配置文件,实现自动化(前提团队约约定俗成目录结构)。

关键点

工程化项目,我们最终页面看到的都是打包后的代码加载出来的,而我们代码目录结构是存在编译时的,如果要在打包过程中读取到源码目录结构,需要使用如下api,根据环境的不同,对应实现也不一样。

vite环境

import.meta.glob

webpack环境

require.context

实现

目录结构

  • xxx/page.js路由配置其他信息
  • xxx/xxx.vue,为路由组件
js 复制代码
src/
  views/
    about/
      index.vue
      page.js
    home/
      index.vue
      page.js
    /router
      index.js  

router/index.js

js 复制代码
import { createWebHistory, createRouter } from 'vue-router'

const data = import.meta.glob("../views/**/page.js", {
  eager: true,
  import: "default"
})

const components = import.meta.glob("../views/**/index.vue", {
  eager: true,
  import: "default"
})

const routes = Object.entries(data).map(([path, meta]) => {
  console.log("path, meta--", path, meta)
  const newPath = path.replace("../views", "").replace("/page.js", "").toLowerCase() || "/"
  const name = newPath.split("/").join("-").replace(/^-/, "") || "index"
  const componentPath = path.replace("/page.js", "/index.vue")
  const callbackfn = components[componentPath]
  return {
    path: newPath,
    meta: meta,
    name,
    component: callbackfn
  }
})


const router = createRouter({
  history: createWebHistory("/"),
  routes,

})

export default router

views/about/index.vue

js 复制代码
<template>
  <div>about</div>
</template>
  <script setup></script>

views/home/index.vue

js 复制代码
<template>
  <div>home</div>
</template>
  <script setup></script>

注意

import.meta.glob是在编译时运行的,在打包后,vite工具会将我们源代码转成如下示例:

源代码

js 复制代码
// src/main.js
const components = import.meta.glob('./components/[A-Z]*.vue', { 
  eager: true,
  import: 'default'
})

编译后

js 复制代码
// 编译后的代码(简化)
const components = {
  './components/Button.vue': ButtonComponent,
  './components/Input.vue': InputComponent,
  './components/Modal.vue': ModalComponent
  // 注意:不匹配 [A-Z]*.vue 模式的文件不会被包含
}

webpack环境下的require.context同理

总结

按照约定的路由模块的文件模块层级写法,我们就不需要重复去配置来路由了,只需要按照目录规范书写代码和配置即可,当然,除上面的方法外,我们还可以直接使用node读取模块,然后自动生成路由文件。

扩展应用

除上面的自动注册路由之外,我们还可以扩展如下自动化相关功能

  • 自动注册组件
  • 功能模块聚合
  • 状态管理模块注册
  • 多语言模块自动生成
  • ....
相关推荐
晚霞的不甘42 分钟前
Flutter for OpenHarmony构建全功能视差侧滑菜单系统:从动效设计到多页面导航的完整实践
前端·学习·flutter·microsoft·前端框架·交互
黎子越42 分钟前
python相关练习
java·前端·python
摘星编程1 小时前
用React Native开发OpenHarmony应用:StickyHeader粘性标题
javascript·react native·react.js
A_nanda1 小时前
c# 用VUE+elmentPlus生成简单管理系统
javascript·vue.js·c#
天天进步20151 小时前
Motia事件驱动的内核:深入适配器(Adapter)层看消息队列的流转
javascript
北极糊的狐1 小时前
若依项目vue前端启动键入npm run dev 报错:不是内部或外部命令,也不是可运行的程序或批处理文件。
前端·javascript·vue.js
XRJ040618xrj1 小时前
Nginx下构建PC站点
服务器·前端·nginx
We་ct2 小时前
LeetCode 289. 生命游戏:题解+优化,从基础到原地最优
前端·算法·leetcode·矩阵·typescript
有诺千金2 小时前
VUE3入门很简单(4)---组件通信(props)
前端·javascript·vue.js
2501_944711432 小时前
Vue-路由懒加载与组件懒加载
前端·javascript·vue.js