Property ‘context‘ does not exist on type ‘NodeRequire‘.ts(2339)

文章讲述了在Vue3项目中使用require.context引发的错误,尝试通过安装@types/webpack-env和修改tsconfig.json配置来解决,但问题未完全消除。最终发现需在tsconfig.vitest.json中添加webpack-env到types才消除编译错误,然而浏览器仍报requireisnotdefined,因为require是webpack的方法,不适用于Vite构建的项目。建议使用Vite的导入机制替代require.context。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近使用vue3官方脚手架创建的项目,在执行下面的代码后报错:

const files = require.context('./modules', false, /\.js$/)

查阅相关资料,有人提出解决方法如下,安装@types/webpack-env依赖:

npm i -D @types/webpack-env

修改tsconfig.json:

{
  "compilerOptions": {
    "declaration": false,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "lib": ["es6", "dom"],
    "module": "es6",
    "moduleResolution": "node",
    "sourceMap": true,
    "target": "es5",
    "types": [
      "webpack",
      "webpack-env" // 加入这个
    ]
  },
}

但是发现,开始的报错并没有消失。

在项目根目录找到tsconfig.vitest.json,在"types": [“node”, “jsdom”]中加入"webpack-env"

{
  "extends": "./tsconfig.app.json",
  "exclude": [],
  "compilerOptions": {
    "composite": true,
    "lib": [],
    "types": ["node", "jsdom","webpack-env"]
  }
}

报错消失。

虽然编辑器不报错了,但是浏览器却无法识别这个方法:
Ucaught ReferenceError: require is not defined

结论:这个方法是webpack提供的,既然都用Vite了就别用这个方法了。

它的作用无非就是引入了一个目录下的所有文件,大不了手动引入。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值