ElMessage自动引入,样式缺失和ts esline 报错问题解决

一. 环境

复制代码
"unplugin-auto-import": "^0.17.6",
"vue": "^3.3.8",
"vite": "^5.0.0", 
"typescript": "^5.2.2",

二. ElMessage样式缺失问题.

以下有两种解决方法

  1. 方法一: 配置了自动引用后,在使用ElMessage的时候去掉
ts 复制代码
import { ElMessage } from 'element-plus';

这个会产生esline报错,和ts报错, 后面有解决方法

  1. 方法二: 引入ElMessage的样式
ts 复制代码
import { ElMessage } from 'element-plus';
import 'element-plus/theme-chalk/src/index.scss'

在配置了自动引用, 这样去使用显然不是优雅的, 而且每次时候都需要进行引入

当然可以在main.ts中进行全局引用, 当然这还是不优雅的 (所以看下面 ↓)

三. 解决去掉import { ElMessage } 引起的esline,ts 报错问题

tsconfig.json中在include内添加**/*.d.ts

json 复制代码
	...
 "exclude": ["node_modules"],
 "include": ["src/**/*.ts", "src/**/*.tsx", "src/**/*.vue", "**/*.d.ts"],
	...

node_modules中找到unplugin-auto-import阅读他的readme.md文件

看到了英文, 嘿嘿打开翻译

按照他说的进行配置vite.config.ts

ts 复制代码
// ...
AutoImport({
	resolvers: [ElementPlusResolver()],
	eslintrc: {
	enabled: true, // <-- this
	},
})
//	...

这会生成一个.eslintrc-auto-import.json文件, 这时我们需要更新我们的.eslintrc.cjs文件
.eslintrc.cjs

json 复制代码
	"extends": [
			...
		'./.eslintrc-auto-import.json', //加上这一行
	]

这里就完成了

如果按照这个过程没有配置成功, 可以找项目引入unplugin-auto-import的Readme文件, 按照提供的方法去搞

参考文章: <自动引入ElMessage,解决ts声明及ESLint报错问题>

感谢原文作者

相关推荐
差点GDP13 小时前
模拟请求测试 Fake Rest API Test
前端·网络·json
酒尘&13 小时前
Hook学习-上篇
前端·学习·react.js·前端框架·react
houyhea14 小时前
从香港竹脚手架到前端脚手架:那些"借来"的发展智慧与安全警示
前端
哈哈~haha14 小时前
Step 14: Custom CSS and Theme Colors 自定义CSS类
前端·css·ui5
Ndmzi14 小时前
Matlab编程技巧:自定义Simulink菜单(理解补充)
前端·javascript·python
勇气要爆发14 小时前
物种起源—JavaScript原型链详解
开发语言·javascript·原型模式
我命由我1234514 小时前
VSCode - VSCode 修改文件树缩进
前端·ide·vscode·前端框架·编辑器·html·js
SoaringHeart15 小时前
Flutter组件封装:验证码倒计时按钮 TimerButton
前端·flutter
San30.15 小时前
深入理解 JavaScript OOP:从一个「就地编辑组件」看清封装、状态与原型链
开发语言·前端·javascript·ecmascript
AAA阿giao16 小时前
JavaScript 原型与原型链:从零到精通的深度解析
前端·javascript·原型·原型模式·prototype·原型链