告别手写字符串!UniApp 路由全自动类型生成工具

一、 开发背景与痛点

在进行 UniApp + TypeScript 开发时,路由跳转一直是一个让人头疼的问题。由于 UniApp 的路由定义在 pages.json 中,我们在代码里调用跳转 API 时,往往面临以下窘境:

  1. 纯手动输入 :每次 uni.navigateTo 都要手动拼写路径字符串,不仅慢,还容易写错。
  2. 重构噩梦 :一旦在 pages.json 中修改了页面路径,全局搜一遍字符串去改,极易遗漏引发线上 Bug。
  3. 无类型提示:IDE 无法感知哪些路径是合法的,跳转全靠"盲猜"。
  4. 分包路径复杂:主包、分包路径层级深,拼接字符串极其痛苦。

为了彻底解决这些 DX(开发者体验)痛点,我开发了 vite-plugin-uniapp-router-type 插件。


二、 插件初衷与目的

本插件的核心思路非常简单:让代码跑在配置前面

通过监听 pages.json 的变化,插件会自动解析其中的 pagessubPackages 配置,并实时生成一份全量的路径类型声明文件。它能让你的跳转代码从"盲打"变成"点选",极大地提升开发效率和代码健壮性。


三、 安装与配置

该插件仅在开发阶段用于辅助生成类型文件,因此建议安装为 开发依赖 (-D)

1. 安装插件

Bash

python 复制代码
npm install vite-plugin-uniapp-router-type -D
# 或者使用 pnpm
pnpm add vite-plugin-uniapp-router-type -D

2. Vite 配置

在项目根目录的 vite.config.ts 中引入并添加到 plugins 数组中:

TypeScript

javascript 复制代码
import { defineConfig } from 'vite';
import uni from '@dcloudio/vite-plugin-uni';
import uniappRouterType from 'vite-plugin-uniapp-router-type';

export default defineConfig({
  plugins: [
    uni(),
    // 默认配置下,插件会读取 src/pages.json 并在 src/types/router.d.ts 生成类型
    uniappRouterType({
      // 可选配置 (默认值如下)
      // pagesJsonPath: 'src/pages.json', // pages.json 路径
      // outputDir: 'src/types',         // 类型定义输出目录
      // fileName: 'router.d.ts'         // 生成的文件名
    })
  ]
});

四、 功能示例

1. 丝滑的路径自动补全

由于插件自动增强了全局 Uni 接口的跳转方法,当你输入 / 时,IDE 会自动弹出所有在 pages.json 中定义过的合法路径:

TypeScript

php 复制代码
// IDE 将自动提示所有合法路径
uni.navigateTo({
  url: '/pages/index/index?id=1' // 路径受到类型强约束,拼错会报错
});

// 同样支持 switchTab 的路径过滤
uni.switchTab({
  url: '/pages/tabbar/home' 
});

2. 手动引用导出的类型

如果你需要为组件的 Props 或自定义函数定义路由相关的类型,可以直接引用导出的 PagePathPageUrl

TypeScript

ini 复制代码
import type { PagePath, PageUrl } from '@/types/router';

// 仅代表纯路径
const myPath: PagePath = '/pages/user/info'; 

// 代表路径或带参数的 URL (例如: /pages/detail/index?id=123)
const myUrl: PageUrl = '/pages/detail/index?id=100'; 

五、 结语

vite-plugin-uniapp-router-type 现已开源并发布至 npm。它的初衷是让 UniApp 的开发也能拥有像 Web 路由那样的强类型保障。

如果这个插件能帮你在开发中少写两个 Bug,少熬两个夜,请给项目点个 Star 支持一下!

欢迎大家在评论区提出宝贵的意见,我会持续优化迭代。

相关推荐
小时前端1 小时前
微信小程序选不了本地文件?用 web-view + H5 一招搞定
前端·微信小程序·uni-app
掘金安东尼2 小时前
从平面到空间:用 React Three Fiber 构建 3D 产品网格
前端·javascript·面试
小时前端2 小时前
HTTPS 页面加载 HTTP 脚本被拦?同源代理来救场
前端·https
用户683709359552 小时前
在 Rokid AR 眼镜里玩消消乐:基于 Unity 2022 LTS + UXR 3.0 SDK 的轻量级 AR 游戏尝试
前端
zzjyr2 小时前
@umijs/max 中导出的 request 方法,如何实现 GET/POST/PUT/DELETE 这四种核心请求
前端
swipe2 小时前
#用这 9 个浏览器 API,我把页面从“卡成 PPT”救回到 90+(每个都有能直接抄的例子)
前端·javascript·面试
zzjyr2 小时前
基于 @umijs/max 的 request 补充常见错误统一处理、请求取消、重复请求防抖的完整方案
前端
拖拉斯旋风2 小时前
深入浅出 RAG:从网页爬取到智能问答的完整链路解析
前端
Mintopia2 小时前
Vite 发展现状与回顾:从“极致开发体验”到生态基础设施
前端