😡😡😡早知道有这两个 VueRouter 增强插件,我还加什么班!🚀🚀🚀

前言

昨天介绍了一些 pinia 库,今天迫不及待的来介绍一些今天发现的两个 Vue Router 神器,它们可以用更少的配置、更高的效率构建复杂路由系统!

往期精彩推荐

正文

1. unplugin-vue-router

地址:https://github.com/posva/unplugin-vue-router

unplugin-vue-router是一个基于文件系统的类型安全路由插件,为 Vue Router 提供下一代自动化解决方案。

它可以自动扫描 src/pages 文件夹生成路由配置

也提供 TypeScript 类型提示,路径、参数完全类型安全,

并且支持嵌套路由、动态参数、异步加载等复杂场景,

而且与 Vite、Webpack、Rollup 构建工具兼容,支持生成 loader(实验功能)用于服务端数据预加载。

特别适合中大型项目,特别是追求类型安全和结构规范的团队。

bash 复制代码
npm i -D unplugin-vue-router
ts 复制代码
// vite.config.ts
import VueRouter from 'unplugin-vue-router/vite'

export default defineConfig({
  plugins: [
    VueRouter({
      /* options */
    }),
    // ⚠️ Vue must be placed after VueRouter()
    Vue(),
  ],
})

你也可以使用 vue-router/auto-routes 来配合 unplugin-vue-router 自动生成路由配置!

它可以让你直接通过src/pages 目录中生成路由,无需手动配置路由数组。

适合需要快速集成、快速原型开发或不想写重复路由配置的项目,非常适合中小型项目,或是对开发效率要求较高的场景。

ts 复制代码
import { routes, handleHotUpdate } from 'vue-router/auto-routes'
const router = createRouter({
  history: createWebHistory(),
  routes
})

if (import.meta.hot) { 
  handleHotUpdate(router) 
}

2. vue-router-layouts

地址:https://github.com/JohnCampionJr/vite-plugin-vue-layouts

vue-router-layouts 是一个 layout 插件,常与 vite-plugin-pagesunplugin-vue-router 结合使用,用于实现页面级布局功能。

它可以自动识别页面组件中的 layout 配置,并将对应 layout 应用于页面渲染。

同时支持默认 layout、嵌套路由 layout 和动态 layout,可以应对后台系统等复杂布局需求。

通过 setupLayouts 方法与生成的路由集成后,即可自动插入布局逻辑,减少样板代码和人为出错的可能。

特别适合需要多布局切换或页面结构复杂的中大型应用。

bash 复制代码
npm install -D vite-plugin-vue-layouts
ts 复制代码
// vite.config.ts
import Vue from '@vitejs/plugin-vue';
import Pages from 'vite-plugin-pages';
import Layouts from 'vite-plugin-vue-layouts';

export default {
  plugins: [Vue(), Pages(), Layouts()],
};
ts 复制代码
import { createRouter } from 'vue-router'
import { setupLayouts } from 'virtual:generated-layouts'
import generatedRoutes from '~pages'
const routes = setupLayouts(generatedRoutes)
const router = createRouter({
  // ...
  routes,
});

最后

如果你在构建一个 Vue 应用,不妨选择适合自己的路由增强工具来给自己的开发加速!

今天的分享就这些了,感谢大家的阅读,如果文章中存在错误的地方欢迎指正!

往期精彩推荐

相关推荐
狂炫冰美式12 分钟前
人均配了AI, 为什么公司还是没变快? 🤔 本质还是分布式系统问题
前端·后端·架构
乘风gg1 小时前
多 Agent 不是万能的!搞懂这 5 个原则,少走 1 年弯路!
前端·agent·ai编程
猩猩程序员2 小时前
Vercel 推出 Agent 框架 Eve:让 AI Agent 像写 Web 应用一样简单
前端
爱读源码的大都督2 小时前
Claude Code源码分析(三):为什么系统提示词中需要有tools呢?
前端·人工智能·后端
爱勇宝2 小时前
Claude Code 被曝暗藏“隐形检测”代码:封代理不是最可怕的,可怕的是你根本不知道它在干什么
前端·后端·程序员
小牛不牛的程序员3 小时前
我用 Claude Code 半天撸完了一个完整网站,AI 编程到底提升了多少效率?
前端
东风破_3 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
ITOM运维行者3 小时前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端
monologues3 小时前
深入 Vue 3 源码:响应式系统的精妙设计与编译优化
前端
hunterandroid3 小时前
Paging 3 分页:从手动分页到声明式加载
前端