【node 解决】---- UnhandledPromiseRejectionWarning: TypeError: Invalid host defined

【node 解决】---- UnhandledPromiseRejectionWarning: TypeError: Invalid host defined options

1. 问题描述

在使用 node 进行文件批量上传开发的时候,本地可以正常运行,但是打包后运行就报错:

javascript 复制代码
UnhandledPromiseRejectionWarning: TypeError: Invalid host defined options

at C:\snapshot\hl_upload\upload.js

2. 报错截图

3. 报错原因分析

该错误通常与动态导入或不兼容的模块使用有关。 错误源于使用了动态导入 node-fetch ,这在打包后的可执行文件中可能不被支持。需要将其改为使用 require 方式导入。

4. 修改导入

4.1 动态引入代码

ini 复制代码
let fetch;
(async () => {
  fetch = (await import('node-fetch')).default;
})();

4.2 修改后代码

ini 复制代码
const fetch = require('node-fetch').default;

5. 重新打包运行

运行可执行文件时出现了新的错误: Cannot use import statement outside a module 。这表明 node-fetch 模块内部使用了 ES 模块语法,而我们的项目是以 CommonJS 方式运行的。需要进一步修改代码,确保所有模块都以兼容方式导入。

6. 报错

javascript 复制代码
C:\snapshot\hl_upload\node_modules\node-fetch\src\index.js:9
import http from 'node:http';
^^^^^^

SyntaxError: Cannot use import statement outside a module

7. 错误图片

8. 降低 node-fetch 的版本

node-fetch 版本为 3.3.2,这是一个纯 ES 模块版本,可能与我们的 CommonJS 项目不兼容。尝试将其降级到 2.x 版本,该版本支持 CommonJS。

9. 总结

  1. 将 node-fetch 的动态导入方式改为 require 方式导入。
  2. 将 node-fetch 版本从 3.3.2 降级到 2.6.7,以确保与 CommonJS 兼容。
  3. 重新安装依赖并重新打包项目。

修改后,hl_upload.exe 文件能够正常运行,上传功能和 icon.js 文件生成均工作正常。

相关推荐
fruge1 小时前
Vue项目中的Electron桌面应用开发实践指南
前端·vue.js·electron
漂流瓶jz7 小时前
Webpack中各种devtool配置的含义与SourceMap生成逻辑
前端·javascript·webpack
前端架构师-老李7 小时前
React 中 useCallback 的基本使用和原理解析
前端·react.js·前端框架
木易 士心8 小时前
CSS 中 `data-status` 的使用详解
前端·css
明月与玄武8 小时前
前端缓存战争:回车与刷新按钮的终极对决!
前端·缓存·回车 vs 点击刷新
牧马少女8 小时前
css 画一个圆角渐变色边框
前端·css
zy happy8 小时前
RuoyiApp 在vuex,state存储nickname vue2
前端·javascript·小程序·uni-app·vue·ruoyi
小雨青年9 小时前
Cursor 项目实战:AI播客策划助手(二)—— 多轮交互打磨播客文案的技术实现与实践
前端·人工智能·状态模式·交互
小光学长9 小时前
基于Vue的儿童手工创意店管理系统as8celp7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
meichaoWen9 小时前
【Vue】Vue框架的基础知识强化
前端·javascript·vue.js