升级指南
分为 6
部分的内容:(2025-06-14 周六)
uniapp sdk 升级
uni-helper 插件升级
oxlint 升级
移除 eslint, stylelint
unocss 升级
(可选)vscode 配置文件升级
(可选)
uniapp sdk 升级
sh
pnpm uvm # 升级 uniapp sdk
# 如果以上命令不存在,请使用下面的
npx @dcloudio/uvm@latest
然后进入交互式的升级模式,按照提示进行升级。期间包管理器选择 pnpm
。
升级完后,会自动引入 vue-i18n
,不需要的可以删除它。(可选)
uni-helper 插件升级
sh
"@uni-helper/uni-types": "1.0.0-alpha.3",
"@uni-helper/unocss-preset-uni": "^0.2.11",
"@uni-helper/vite-plugin-uni-components": "0.2.0",
"@uni-helper/vite-plugin-uni-layouts": "0.1.10",
"@uni-helper/vite-plugin-uni-manifest": "0.2.8",
"@uni-helper/vite-plugin-uni-pages": "0.2.28",
"@uni-helper/vite-plugin-uni-platform": "0.0.4",
把你项目里面的 package.json
里面的相关依赖包版本改成上面的。然后执行 pnpm i
安装。
oxlint 升级
sh
pnpm add -D oxlint@v1.0.0 # 注意不要贪最新,最新的 v1.1.0 有问题,会报错。
package.json
里面的 "lint-staged"
内容改为:
json
"lint-staged": {
"**/*.{html,cjs,json,md,scss,css,txt}": [
"prettier --write --cache"
],
"**/*.{js,jsx,ts,tsx,vue,mjs,cjs,mts,cts}": [
"oxlint --fix",
"prettier --write --cache"
],
"!**/{node_modules,dist}/**": []
},
package.json
里面的 scripts
添加:
json
scripts: {
// ... 其他
"lint": "oxlint",
"lint-fix": "oxlint --fix"
}
然后在项目根目录新建 .oxlintrc.json
文件,内容如下:
json
{
"$schema": "./node_modules/oxlint/configuration_schema.json",
"extends": ["config:recommended"],
"plugins": ["import", "typescript", "unicorn"],
"rules": {
"no-console": "off",
"no-unused-vars": "off"
},
"env": {
"es6": true
},
"globals": {
"foo": "readonly"
},
"ignorePatterns": [
"node_modules",
"dist",
"src/static/**",
"src/uni_modules/**",
"vite.config.ts",
"uno.config.ts",
"pages.config.ts",
"manifest.config.ts"
],
"settings": {},
"overrides": [
{
"files": ["*.test.ts", "*.spec.ts"],
"rules": {
"@typescript-eslint/no-explicit-any": "off"
}
}
]
}
移除 eslint, stylelint
上面配置了 oxlint
后,eslint
不需要了,可以把 依赖包
和 配置文件
都都删除。
stylelint
可以保留也可以删除,因为几乎都是用 unocss
来写样式的,所以 stylelint
不要也可以。
unocss 升级(可选)
1、升级 unocss
sh
pnpm add -D unocss@65.4.2 # 注意不要贪最新,最新的 v66+ 有问题,会报错。
2、 更新 uno.config.ts
配置文件
ts
// https://www.npmjs.com/package/@uni-helper/unocss-preset-uni
import { presetUni } from '@uni-helper/unocss-preset-uni'
import {
defineConfig,
presetIcons,
presetAttributify,
transformerDirectives,
transformerVariantGroup,
} from 'unocss'
export default defineConfig({
presets: [
presetUni({
attributify: {
// prefix: 'fg-', // 如果加前缀,则需要在代码里面使用 `fg-` 前缀,如:<div fg-border="1px solid #000"></div>
prefixedOnly: true,
},
}),
presetIcons({
scale: 1.2,
warn: true,
extraProperties: {
display: 'inline-block',
'vertical-align': 'middle',
},
}),
// 支持css class属性化
presetAttributify(),
],
transformers: [
// 启用指令功能:主要用于支持 @apply、@screen 和 theme() 等 CSS 指令
transformerDirectives(),
// 启用 () 分组功能
// 支持css class组合,eg: `<div class="hover:(bg-gray-400 font-medium) font-(light mono)">测试 unocss</div>`
transformerVariantGroup(),
],
shortcuts: [
{
center: 'flex justify-center items-center',
},
],
rules: [
[
'p-safe',
{
padding:
'env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)',
},
],
['pt-safe', { 'padding-top': 'env(safe-area-inset-top)' }],
['pb-safe', { 'padding-bottom': 'env(safe-area-inset-bottom)' }],
],
theme: {
colors: {
/** 主题色,用法如: text-primary */
primary: 'var(--wot-color-theme,#0957DE)',
},
fontSize: {
/** 提供更小号的字体,用法如:text-2xs */
'2xs': ['20rpx', '28rpx'],
'3xs': ['18rpx', '26rpx'],
},
},
})
3、 更新 vite.config.ts
中 unocss
的引入方式:
ts
export default async ({ command, mode }) => {
// @see https://unocss.dev/
const UnoCSS = (await import('unocss/vite')).default
// ... 其他代码
})
vscode 配置文件升级
.vscode/settings.json
里面 explorer.fileNesting.patterns
配置如下:
json
"explorer.fileNesting.patterns": {
"README.md": "index.html,favicon.ico,robots.txt,CHANGELOG.md",
"pages.config.ts": "manifest.config.ts,openapi-ts-request.config.ts",
"package.json": "pnpm-lock.yaml,pnpm-workspace.yaml,LICENSE,.gitattributes,.gitignore,.gitpod.yml,CNAME,.npmrc,.browserslistrc",
".oxlintrc.json": "tsconfig.json,.commitlintrc.*,.prettier*,.editorconfig,.commitlint.cjs,.eslint*"
}