我用uniapp开发app用到的uniapp插件

1. @uni-helper/vite-plugin-uni-manifest:清单文件处理

该插件专门用于处理 manifest.config.ts 配置文件,将其转换为 UniApp 所需的最终 manifest.json 文件。通过 TypeScript 配置支持,开发者可以获得更好的类型提示和配置验证。

2. @uni-helper/vite-plugin-uni-pages:智能路由生成
  • 自动路由扫描 :自动扫描 src/pages 目录结构,动态生成路由配置
  • 分包支持:完整支持 UniApp 的分包路由配置
  • 类型安全 :自动生成类型定义文件 src/types/uni-pages.d.ts,提供完整的 TypeScript 支持
3. @uni-helper/vite-plugin-uni-layouts:统一布局管理

提供完整的页面布局系统解决方案,支持:

  • 统一的布局组件管理
  • 灵活的布局切换机制
  • 页面与布局的自动关联
4. @uni-helper/vite-plugin-uni-platform:平台检测与优化
  • 平台感知:自动检测目标运行平台
  • 编译优化:提供平台特定的构建优化策略
  • 协同工作 :需要与 uni-pages 插件配合使用,实现最佳效果
5. @dcloudio/vite-plugin-uni:核心构建插件

作为 UniApp 的官方核心构建插件,需要注意:

  • 引入顺序:必须在所有 UniHelper 系列插件之后引入
  • 代码混淆:提供强大的代码混淆能力
  • 配置方式 :通过 vite.config.js 中的 terserOptions 自定义 Terser 混淆配置

配置示例

javascript 复制代码
// vite.config.js
export default {
  plugins: [
    // UniHelper 插件系列
    uniManifest(),
    UniPages({
        exclude: ['**/components/**/**.*'],
        routeBlockLang: 'json5', // 虽然设了默认值,但是vue文件还是要加上 lang="json5", 这样才能很好地格式化
        // homePage 通过 vue 文件的 route-block 的type="home"来设定
        // pages 目录为 src/pages,分包目录不能配置在pages目录下
        subPackages: [
          'src/pages-home',
          'src/pages-message',
          'src/pages-user',
          'src/pages-work',
          'src/pages-sub',
        ], // 是个数组,可以配置多个,但是不能为pages里面的目录
        dts: 'src/types/uni-pages.d.ts',
      }),
    uniLayouts(),
    uniPlatform(),
    
    // 官方核心插件(必须最后引入)
    uni()
  ],
  build: {
    terserOptions: {
      // 自定义混淆配置
      compress: {
        drop_console: true
      }
    }
  }
}

这套插件组合为 UniApp 开发提供了从配置管理、路由生成、布局系统到平台优化的完整解决方案,显著提升了开发效率和代码质量。

相关推荐
smallLabel7 小时前
记一次 OpenClaw 飞书插件接入填坑指南: Error: spawn EINVAL
前端
zzjyr7 小时前
react前端项目 fetch原生 与 umijs request 四种请求区别
前端
我叫黑大帅7 小时前
前端总说的防抖与节流到底是什么?
前端·javascript·面试
小时前端7 小时前
微信小程序选不了本地文件?用 web-view + H5 一招搞定
前端·微信小程序·uni-app
71Ove7 小时前
告别手写字符串!UniApp 路由全自动类型生成工具
前端
掘金安东尼7 小时前
从平面到空间:用 React Three Fiber 构建 3D 产品网格
前端·javascript·面试
小时前端7 小时前
HTTPS 页面加载 HTTP 脚本被拦?同源代理来救场
前端·https
用户683709359557 小时前
在 Rokid AR 眼镜里玩消消乐:基于 Unity 2022 LTS + UXR 3.0 SDK 的轻量级 AR 游戏尝试
前端
zzjyr7 小时前
@umijs/max 中导出的 request 方法,如何实现 GET/POST/PUT/DELETE 这四种核心请求
前端
swipe7 小时前
#用这 9 个浏览器 API,我把页面从“卡成 PPT”救回到 90+(每个都有能直接抄的例子)
前端·javascript·面试