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

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

相关推荐
linux_cfan4 分钟前
2026版 WordPress 视频插件终极选型:知识付费创作者如何低成本打造专业在线课堂?
前端·javascript·音视频·html5
pas13620 分钟前
46-mini-vue 实现编译 template 为 render 函数
前端·javascript·vue.js
YuMiao43 分钟前
把 WebSocket 服务迁移到 Cloudflare Durable Objects —— 以一次协同编辑实战为例
javascript·node.js
数据知道2 小时前
JSON 与 BSON 深度解析:理解 MongoDB 底层数据格式与扩展类型。
数据库·mongodb·json
Highcharts.js2 小时前
Highcharts跨域数据加载完全指南:JSONP原理与实战
javascript·数据库·开发文档·highcharts·图表开发·跨域数据
skywalk81632 小时前
electrobun 使用TypeScript构建超快速、小巧且跨平台的桌面应用程序(待续)
前端·javascript·typescript
薛一半4 小时前
React的数据绑定
前端·javascript·react.js
爱看书的小沐4 小时前
【小沐杂货铺】基于Three.js渲染三维无人机Drone(WebGL / vue / react )
javascript·vue.js·react.js·无人机·webgl·three.js·drone
ShenJLLL11 小时前
vue部分知识点.
前端·javascript·vue.js·前端框架
Never_Satisfied19 小时前
在JavaScript / HTML中,数组查找第一个符合要求元素
开发语言·javascript·html