我用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 开发提供了从配置管理、路由生成、布局系统到平台优化的完整解决方案,显著提升了开发效率和代码质量。

相关推荐
问心无愧05138 小时前
ctf show web入门160 161
前端·笔记
李小白668 小时前
第四天-WEB服务器基本原理,IIS服务
运维·服务器·前端
humcomm9 小时前
AI编程时代新前端职位
前端·ai编程
好家伙VCC9 小时前
Web Components主题热切换方案揭秘
java·前端
甲维斯9 小时前
Kimi版超级玛丽效果“惊人”,配额不足5厘米!
前端·人工智能
hboot10 小时前
AI工程师第一课 - Python
前端·后端·python
凉菜凉凉10 小时前
AI时代,被抛弃的前端
前端·ai
console.log('npc')10 小时前
AI前端工程与生成式UI学习路线
前端·人工智能·ui
梦曦i10 小时前
uni-router v1.1.1发布:守卫超时保护+路由监听
前端·uni-app
qq_25183645710 小时前
基于java Web网络订餐系统设计与实现 源码文档
java·开发语言·前端