基于文件名 (
*.<h5|mp-weixin|app>.*
) 的按平台编译插件
pnpm i -D @uni-helper/vite-plugin-uni-platform
// vite.config.ts
import { defineConfig } from 'vite'
import Uni from '@dcloudio/vite-plugin-uni'
import UniPlatform from '@uni-helper/vite-plugin-uni-platform'
export default defineConfig({
plugins: [UniPlatform(), Uni()],
})
现在所有的带有平台标识符的文件都会被自动替换!
flowchart LR
subgraph 源目录 src/
src-index[pages/index.vue]
src-index-h5[pages/index.h5.vue]
src-index-mp[pages/index.mp-weixin.vue]
end
subgraph 微信小程序环境
src-index-mp --> pages/index.js
src-index-mp --> pages/index.json
src-index-mp --> pages/index.wxml
src-index-mp --> pages/index.wxss
end
subgraph H5环境
src-index-h5 --> assets/pages-index.js
src-index-h5 --> assets/index.css
end
subgraph 其他环境
src-index --> pages/pages-index.js
end
与 @uni-helper/vite-plugin-uni-pages 插件一起使用
[!NOTE] 自 vite-plugin-uni-pages 插件 0.2.12 起,不再需要进行处理。
// vite.config.ts
import { defineConfig } from 'vite'
import Uni from '@dcloudio/vite-plugin-uni'
import UniPlatform from '@uni-helper/vite-plugin-uni-platform'
import UniPages from '@uni-helper/vite-plugin-uni-pages'
import { platform } from '@uni-helper/uni-env'
export default defineConfig({
plugins: [
UniPlatform(),
UniPages({
onBeforeWriteFile(ctx) {
const pagesMap = new Map()
const pages = ctx.pageMetaData
.filter(v => !/\..*$/.test(v.path) || v.path.includes(platform))
.map(v => ({ ...v, path: v.path.replace(/\..*$/, '') }))
pages.forEach(v => pagesMap.set(v.path, v))
ctx.pageMetaData = [...pagesMap.values()]
},
}),
Uni(),
],
})