IoTSharp前端VUE采用npm run build编译提示require() of ES Module 出错

IoTSharp前端代码在IoTSharp/ClientApp是采用VUE开发的代码,采用npm run build编译不通过,出现如下问题:

一、问题1:Error ERR_REQUIRE_ESM: require() of ES Module

IoTSharp前端代码ClientApp里用npm run build编译提示如下错语"The CJS build of Vite's Node API is deprecated. See https://vite.dev/guide/troubleshooting.html#vite-cjs-node-api-deprecated for more details. failed to load config from E:\IOT\IoTSharp\IoTSharp\ClientApp\vite.config.ts error during build: Error ERR_REQUIRE_ESM: require() of ES Module E:\IOT\IoTSharp\IoTSharp\ClientApp\node_modules\@iconify\utils\node_modules\package-manager-detector\dist\detect.mjs not supported. Instead change the require of E:\IOT\IoTSharp\IoTSharp\ClientApp\node_modules\@iconify\utils\node_modules\package-manager-detector\dist\detect.mjs to a dynamic import() which is available in all CommonJS modules.

这个错误表明在构建过程中,Vite 无法正确加载一个 ES Module(.mjs 文件),因为使用了 require(),而 ES Modules 不支持通过 require() 加载。

Vite 的 CJS 构建已被弃用,建议迁移到 ECMAScript Modules (ESM)。以下是两种解决方案:

1)解决方案:在 package.json 中添加 "type": "module"

在项目的 package.json 文件中添加 "type": "module",这会告诉 Node.js 将 .js 文件作为 ESM 处理:

复制代码
{
  "type": "module"
}

通过在 package.json 中添加 "type": "module" 或将 vite.config.ts 文件改名为 vite.config.mts,可以解决 Vite 的 CJS 构建弃用警告。通过动态导入 ES Modules、更新依赖项、清理和重新安装依赖、启用详细日志,通常可以解决 ERR_REQUIRE_ESM 错误。

二、问题2:vueSetupExtend is not a function

vite:config bundled config file loaded in 959.98ms +0ms failed to load config from E:\IOT\IoTSharp\IoTSharp\ClientApp\vite.config.ts error during build: TypeError: vueSetupExtend is not a function。

根据你的问题和提供的搜索结果,以下是解决 TypeError: vueSetupExtend is not a function 错误的详细步骤:

1)解决方案: 安装 vite-plugin-vue-setup-extend组件

错误信息表明 vueSetupExtend 被错误地导入或使用了。确保你正确导入了 vueSetupExtend 插件。根据搜索结果,vite-plugin-vue-setup-extend-plus 插件可能存在兼容性问题,建议使用 vite-plugin-vue-setup-extend

三、重新编译问题解决

相关推荐
yuanyxh13 小时前
macOS 应用 - 纯对话生成
前端·macos·ai编程
大家的林语冰13 小时前
ES5 凉凉,Babel 8 正式发布,默认不再编译为 ES5 和 CJS......
前端·javascript·前端工程化
光影少年14 小时前
react批量更新、同步/异步更新场景
前端·react.js·掘金·金石计划
假如让我当三天老蒯14 小时前
模块化:ES Module 与 CommonJS 的区别
前端·面试
用户409501157731714 小时前
Private Forge v2.0 发布:12大前端业务场景技能系统
前端
weedsfly15 小时前
异步编程全景与事件循环——彻底搞懂 JS 执行机制
前端·javascript
用户0595401744615 小时前
AI Agent记忆测试踩坑实录:Mock骗了我一周,Mem0+pytest一招破局
前端·css
用户17335980753715 小时前
纯前端 PDF 数字签名实战:Vue 3 + pdf-lib 在浏览器里完成签名嵌入
前端·javascript
IT_陈寒16 小时前
SpringBoot自动配置的坑,我爬了三天才出来
前端·人工智能·后端
Avan_菜菜1 天前
AI 能写代码了,为什么我反而开始要求它先写文档?
前端·github·ai编程