解决百度网盘安装报错: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

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

相关推荐
꧁꫞꯭零꯭点꯭꫞꧂29 分钟前
G6绘制机柜 以及机柜设备的demo
前端·javascript·vue.js
Lee川1 小时前
🚀 JavaScript 内存大揭秘:从“栈堆搬家”到“闭包时空胶囊”
前端·javascript·面试
唐叔在学习1 小时前
TodoList应用:SPA应用首屏性能优化实践
前端·javascript·性能优化
kyriewen1 小时前
别再滥用 iframe 了!这些场景下它其实是最优解
前端·javascript·html
恪愚1 小时前
three | 材质 Material
前端·javascript·材质
昨日余光2 小时前
建议收藏!我开发了一个免费无限制的AI绘画公益站!
开发语言·前端·javascript·ai作画·typescript
吃不饱的得可可2 小时前
【三方库】jsoncpp
c++·json
guodashen0072 小时前
在安卓端启动一个服务器接口,用于接收post请求的json数据
android·服务器·json
optimistic_chen2 小时前
【Vue入门】创建Vue工程环境和响应式函数
前端·javascript·vue.js·前端框架·html
xChive2 小时前
ECharts-大屏开发复习记录与踩坑总结
前端·javascript·echarts