目录
- 1,按需引入问题
- 2,Typescript 报错解决
- 3,eslint 报错解决
1,按需引入问题
vant4 通过按需引入的配置 使用组件时,会同时将样式自动导入。
所以可直接使用相关的 API 方法,样式也没有问题。比如,
showToast('提示内容');
但如果在按需引入配置的基础上,又再次导入,
import { showToast } from 'vant';
showToast('提示内容');
同时没有在 src/main.ts
中导入相关样式文件,使用时样式就会出问题。
import "vant/es/toast/style";
所以统一直接使用相关 API 和组件即可。
2,Typescript 报错解决
但在 .ts
文件中,因为没有显示导入,所以会有如下报错:
一般来说,这个问题需要手动添加类型声明文件,增加使用的全局变量即可。
解决:
通过 Vite 配置按需引入后,会在项目根目录下生成 auto-imports.d.ts
,
/* eslint-disable */
/* prettier-ignore */
// @ts-nocheck
// noinspection JSUnusedGlobalSymbols
// Generated by unplugin-auto-import
export {}
declare global {
const showToast: (typeof import("vant/es"))["showToast"];
}
这就是我们需要的类型声明文件,把它添加到 tsconfig.json
中即可。
{
// ...
"include": ["src/**/*.ts", "src/**/*.tsx", "src/**/*.vue", "auto-imports.d.ts"]
}
3,eslint 报错解决
同样的,因为没有显示导入,eslint 检查时也会有如下报错:
解决:在 .eslintrc.json
中设置全局变量即可。
{
// ...
"globals": {
"showToast": "readonly"
}
}
以上。