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报错问题>

感谢原文作者

相关推荐
码蜂窝编程官方2 分钟前
【含开题报告+文档+PPT+源码】基于SpringBoot+Vue的虎鲸旅游攻略网的设计与实现
java·vue.js·spring boot·后端·spring·旅游
gqkmiss2 分钟前
Chrome 浏览器 131 版本开发者工具(DevTools)更新内容
前端·chrome·浏览器·chrome devtools
Summer不秃8 分钟前
Flutter之使用mqtt进行连接和信息传输的使用案例
前端·flutter
旭日猎鹰12 分钟前
Flutter踩坑记录(二)-- GestureDetector+Expanded点击无效果
前端·javascript·flutter
Viktor_Ye18 分钟前
高效集成易快报与金蝶应付单的方案
java·前端·数据库
hummhumm21 分钟前
第 25 章 - Golang 项目结构
java·开发语言·前端·后端·python·elasticsearch·golang
乐闻x1 小时前
Vue.js 性能优化指南:掌握 keep-alive 的使用技巧
前端·vue.js·性能优化
一条晒干的咸魚1 小时前
【Web前端】创建我的第一个 Web 表单
服务器·前端·javascript·json·对象·表单
花海少爷1 小时前
第十章 JavaScript的应用课后习题
开发语言·javascript·ecmascript
Amd7941 小时前
Nuxt.js 应用中的 webpack:compiled 事件钩子
前端·webpack·开发·编译·nuxt.js·事件·钩子