报红:找不到名称ref ts(2304)、‘ref‘ is not defined. eslint(no-undef)

接上篇

在上篇介绍了使用 unplugin-auto-import 和 unplugin-vue-components

配置完成后,项目可以正常运行,并且页面也正常显示,但vscode里就是报红

这个报红可能是由于 ts 发出的,也可能是由于 eslint 发出的

具体可以用鼠标悬浮来查看问题源出自谁,以下是我这边的解决方案,大家可以参考:


源于TS 找不到名称ref ts(2304)

这个 ref 是源于vue,但我们没有在这个文件里导入ref,ts也查找不到它的来源,所以报红。

我们要做的就是让 ts 知道它是被引入的就可以,引入它的文件是unplugin-auto-import自动生成的auto-imports.d.ts文件:

我们把这个auto-imports.d.ts 给到 ts 配置文件中的 include ,把这个文件和 ts 做关联,这样 ts 就知道 ref 的确被引入,就不会报红了。


源于Eslint 'ref' is not defined

如果是源于 eslint 的报红,那相对 ts 的处理方法会稍多一丁点儿

需要回归到上篇所说的对 unplugin-auto-import 的配置中:

开启 eslintrc ,让其自动生成**.eslintrc-auto-import.json** 文件

TypeScript 复制代码
eslintrc: {
   enabled: true,
},

找到 eslint 的配置文件(我这里是eslint.config.js,你的可能是.eslintrc.js 或其他名称 )

在该配置文件中找到 extends(如果没有这个配置项追加即可),将自动生成的eslintrc-auto-import.json 添加到 extends 配置项中即可。

TypeScript 复制代码
extends: ['./.eslintrc-auto-import.json'],

保存后,关闭vscode,重新打开原来因该问题报红的文件,ref 的报红就消失了。

打开这个自动生成的文件,我们也可以看到其中有对自动导入的那些模块做全局配置------全局变量,全局变量是在所有文件中都可以访问的变量,不需要显示引入或声明即可使用

相关推荐
我是小趴菜20 小时前
前端如何让图片、视频、pdf等文件在浏览器直接下载而非预览
前端
cg3320 小时前
开源项目自动化:用 GitHub Actions 让每个 Issue 都被温柔以待
前端
haierccc20 小时前
Win7、2008R2、Win10、Win11使用FLASH的方法
前端·javascript·html
We་ct20 小时前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
柠檬味的Cat20 小时前
使用腾讯云COS作为WordPress图床的实践
前端·github·腾讯云
Hilaku20 小时前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试
非凡ghost20 小时前
AIMP(音乐播放软件)
前端·windows·音视频·firefox
xiaotao13120 小时前
Vite 完全学习指南
前端·vite·前端打包
comedate21 小时前
[TypeScript] TypeScript 学习从入门到精通
ubuntu·typescript·前端语言
军军君0121 小时前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维