解决百度网盘安装报错:D 盘 package.json 触发 Electron ESM/CJS 冲突

解决百度网盘安装报错:D 盘 package.json 触发 Electron ESM/CJS 冲突

背景与现象

在 Windows 上安装或启动百度网盘时,主进程报错并直接退出:

复制代码
A JavaScript error occurred in the main process
Uncaught Exception:
Error [ERR_REQUIRE_ESM]: requireO of ES Module
D:\BaiduNetdisk\module\BrowserEngine\resources\core.asar\main.js from
D:\BaiduNetdisk\module\BrowserEngine\resources\app.asar\dist\electron\entry.js not
supported.
main.js is treated as an ES module file as it is a js file whose nearest parent
package.json contains "type": "module" which declares all .js files in that package
scope as ES modules.
Instead rename main.js to end in .cjs, change the requiring code to use dynamic
importO which is available in all CommonJS modules, or change "type": "module" to
'type": "commonjs" in D:\package.json to treat all .js files as CommonJS (using .mjs for
all ES modules instead).
...

提示里有一条非常关键的线索:

  • main.js is treated as an ES module
  • 最近的父级 package.jsonD:\package.json

原因分析

Node/Electron 会按照"就近包作用域"的规则来解析模块类型:

  • 如果某个 .js 文件向上找到最近的 package.json,且其中 "type": "module"
    该作用域内的所有 .js 都会按 ESM 解析。
  • 百度网盘的 Electron 入口仍在使用 require() 加载 main.js
    但它被判定为 ESM,于是抛出 ERR_REQUIRE_ESM

换句话说:D 盘根目录的 package.json 把整个 D:\ 变成了 ESM 作用域

导致 D:\BaiduNetdisk\... 下的 .js 被错误地当成 ES Module。

解决方案(本次采用)

在百度网盘安装目录下放置一个更近的 package.json,覆盖模块类型:

D:\BaiduNetdisk\package.json

内容如下:

json 复制代码
{
  "type": "commonjs"
}

这样 D:\BaiduNetdisk\ 及其子目录中的 .js 会按 CommonJS 解析,

Electron 的 require() 能正常工作。

验证方法

  • 重新启动百度网盘,确认不再弹出 ERR_REQUIRE_ESM
  • 若仍报错,检查是否还有其他上层目录存在影响模块解析的 package.json

可选方案

  1. 把百度网盘安装到不受 D:\package.json 影响的路径(如 C:\Program Files\BaiduNetdisk)。
  2. D:\package.json 不是必需文件,可移除或修改其 "type" 配置。

回滚方式

如需回滚,只需删除或改回以下文件:

  • D:\BaiduNetdisk\package.json

小结

这类报错往往不是应用本身的问题,而是 安装路径中的 package.json 改变了模块解析规则

关键是识别报错里出现的"最近父级 package.json"提示,然后用更近的包作用域进行覆盖。


如果你的环境中存在多个 Node 项目,建议不要在磁盘根目录放 package.json

避免对其它程序产生意外影响。

相关推荐
2501_944525544 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 预算详情页面
android·开发语言·前端·javascript·flutter·ecmascript
摘星编程4 小时前
React Native + OpenHarmony:自定义useFormik表单处理
javascript·react native·react.js
pas1364 小时前
39-mini-vue 实现解析 text 功能
前端·javascript·vue.js
2601_949833395 小时前
flutter_for_openharmony口腔护理app实战+我的实现
开发语言·javascript·flutter
大模型玩家七七6 小时前
混合检索不是折中,而是工程理性
android·java·javascript·数据库·人工智能·深度学习
雨季6666 小时前
Flutter 三端应用实战:OpenHarmony 简易“可展开任务详情卡片”交互模式深度解析
开发语言·前端·javascript·flutter·ui·交互
Sylvia33.6 小时前
足球“文字直播/事件流”API详解:解码比赛的数字DNA
java·服务器·前端·json
陶甜也6 小时前
Vue.js 多项目同端口部署实战:上下文路径配置指南
前端·javascript·vue.js·nginx
雨季6666 小时前
Flutter 三端应用实战:OpenHarmony 简易文本字符计数器开发指南
开发语言·javascript·flutter
蓁蓁啊7 小时前
CMake无法检测外部库变化的问题
java·javascript·c++·物联网