Skip to content

Uni App Vite 项目基础配置

封装 vite.config.ts 的基本配置,开箱即用。

1. 如何使用

安装

bash
pnpm add @plugin-light/project-config-uni-vite -D

vite.config.ts 中添加如下设置:

js
import { getUniVue3ViteConfig } from '@plugin-light/project-config-uni-vite';

import { defineConfig } from 'vite';

export default defineConfig(({ mode }) => {
  return getUniVue3ViteConfig({ mode });
});

2. 参数

完整类型定义

属性类型说明默认值
modestring模式-
unianyuni 插件-
portCommonServerOptions['port']端口,传递给 server.port443
httpsServerhttps 配置,传递给 server.https-
hostCommonServerOptions['host']host 配置,传递给 server.hosttrue
prePluginsArray<Plugin>前置插件-
postPluginsArray<Plugin>后置插件-
optimizeDepsIncludesArray<string>对应 optimizeDeps.include-
removeVueDirectionOptionsIRemoveVueDirectionOptionsremove-vue-direction 插件参数-
hmrServerOptions['hmr']hmr 选项{ timeout: 1000 * 60 * 5 }
warnListICrossGameStyleOptions['warnList']语法警报列表,比如 v-modeldestroyed-
transformWebTagOptionsboolean | TransformWebTagOptionstransform-web-tag postcss 插件参数-
removeSelectorOptionsboolean | RemoveSelectorOptionsremove selector postcss 插件参数-
uniTailwindOptionsboolean | UniTailwindPluginUserOptionsuniTailwind 插件参数-
tailwindcssOptionsboolean | Parameters<typeof tailwindcss>[0]tailwindcss postcss 插件参数-
buildOptionsBuildOptions构建选项-
useChunkSplitboolean是否使用 chunk-splitfalse
useLegacyboolean | LegacyOptions是否使用 @vitejs/plugin-legacy,传递对象格式将作为插件参数false
uniOptionsany传递给 uni 插件的参数-
useESBuildPluginboolean | ESBuildOptions是否使用 rollup-plugin-esbuild,传递对象格式将作为插件参数-

3. 常见问题

3.1. 支持的 node.js 版本

node.js 版本 >= 16

3.2. 环境变量如何注入

支持在环境变量文件中配置 VUE_APP_DIR,环境变量文件可以是 .env, .env.local 等,举例如下:

bash
UNI_INPUT_DIR = './src/project/guandan-match'
VUE_APP_DIR = project/guandan-match

3.3. 对外脚本怎么用

本插件导出了几个脚本,外部可以使用。

  1. 修复 uni-appmonorepo 仓库下打包路径问题

原理是修改了 node_modules/@dcloudio/uni-cli-shared/dist/utils.js 源码中的 normalizeNodeModules 方法,增加了下面这句:

ts
str = str.replace(/^[./]*/, '');

使用方式:

ts
require('@plugin-light/project-config-uni-vite/public-script/uni/fix-uni-dir');
  1. 修复 uni-app 小程序下样式文件变化无法重新编译的问题

小程序开发时,独立的 sass 文件改动后并不会重新编译,用一个全新的示例工程也不可以。看了下源码,uni-app 是用 import('vite').then({build}=>{}) 这种方式来启动的。

解决办法是利用 gulp.watch,监听 ./src/**/*.scss 文件,然后修改下 main.ts,然后这样就能重新编译了。同时加上了 debounce

使用方式:

ts
require('@plugin-light/project-config-uni-vite/public-script/watch/watch-sass')();

3.4. SCSS 警告说明是怎么做的

配置中屏蔽了 importlegacy-js-apimixed-decls 的相关警告信息。

原因如下:

  1. uni-app 会把 uni.scss 放到业务每个 scss 前面,所以 @import 改成 @use 后,会报错 @use rules must be written before any other rules

  2. legacy-js-api 问题,也是 uni-app 中使用了 node-sassrenderSync

  3. mixed-decls 问题,涉及到样式优先级问题,业务自己判断即可

3.5. useChunkSplit 含义是什么

设置 useChunkSplittrue 后,将会开启:

  1. aegis-v2axios 作为外链
  2. 将一些库单独拆包
    • t-comm、press-ui、press-plus、 pmd-npm => pmd-pkg
    • @dcloudio/uni-h5 => uni-h5

仅在 H5 下有效。

3.6. 低版本浏览器兼容是怎么做的

使用方式为,设置 useLegacytrue

原理,使用了 @vitejs/plugin-legacy 这个三方库,以及修复了它不支持 CDN 的问题

是否会影响 H5 在高版本浏览器的性能?基本不会,具体可自行搜索 @vitejs/plugin-legacy 的原理。

如何判断当前项目是运行的的 module 产物,还是 legacy 产物?控制台打印 window.__vite_is_modern_browser,为 true 则表示运行的是 module 产物,否则为 legacy 产物。

3.7. 业务中获取分支名等变量

流水线会注入以下环境变量:

bash
# 分支
VITE_PUBLISH_BRANCH

# 发布人
VITE_PUBLISH_AUTHOR

业务可以参考下面的方式获取:

ts
const CUR_BRANCH = (import.meta.env.VITE_PUBLISH_BRANCH || 'develop').replace(/\//, '.');

const shareUrl = `https://foo/bar.${CUR_BRANCH}/`

4. 更新日志

点此查看