Vant 按需引入导致 Typescript,eslint 报错问题

目录

  • 1,按需引入问题
  • [2,Typescript 报错解决](#2,Typescript 报错解决)
  • [3,eslint 报错解决](#3,eslint 报错解决)

1,按需引入问题

vant4 通过 按需引入的配置 使用组件时,会同时将样式也自动导入。所以可直接使用相关的 API 和组件,不会有问题。比如:

js 复制代码
showToast('提示内容');

但如果在按需引入配置的基础上,又再次导入

js 复制代码
import { showToast } from 'vant';

showToast('提示内容');

同时没有在 src/main.ts 中导入相关样式文件,使用时样式就会出问题

js 复制代码
import "vant/es/toast/style";

解决:2种方式不要混用。

2,Typescript 报错解决

通过按需引入的方式使用相关 API 时,在 .ts 文件中会有如下报错,因为没有显示导入,

一般来说,Typescript 的这个报错,可手动添加类型声明,声明使用了的全局变量即可。

解决

通过 Vite 配置按需引入后,会在项目根目录下生成 auto-imports.d.ts

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 中即可。

json 复制代码
{
	// ...
	"include": ["src/**/*.ts", "src/**/*.tsx", "src/**/*.vue", "auto-imports.d.ts"]
}

3,eslint 报错解决

同样的,因为没有显示导入,eslint 检查时也会有如下报错:

解决 :在 .eslintrc.json 中设置全局变量即可。

json 复制代码
{
	// ...
	"globals": {
		"showToast": "readonly"
	}
}

以上。

相关推荐
gnip1 小时前
链式调用和延迟执行
前端·javascript
SoaringHeart1 小时前
Flutter组件封装:页面点击事件拦截
前端·flutter
杨天天.1 小时前
小程序原生实现音频播放器,下一首上一首切换,拖动进度条等功能
前端·javascript·小程序·音视频
Dragon Wu1 小时前
React state在setInterval里未获取最新值的问题
前端·javascript·react.js·前端框架
Jinuss1 小时前
Vue3源码reactivity响应式篇之watch实现
前端·vue3
YU大宗师1 小时前
React面试题
前端·javascript·react.js
木兮xg1 小时前
react基础篇
前端·react.js·前端框架
ssshooter2 小时前
你知道怎么用 pnpm 临时给某个库打补丁吗?
前端·面试·npm
IT利刃出鞘2 小时前
HTML--最简的二级菜单页面
前端·html
yume_sibai2 小时前
HTML HTML基础(4)
前端·html