electron本地调试时终端输出文字乱码

目录

  • [1. 临时修改终端编码](#1. 临时修改终端编码)
  • [2. 永久修改终端编码](#2. 永久修改终端编码)
  • [3. 修改项目启动脚本](#3. 修改项目启动脚本)
  • [4. 使用 concurrently 工具](#4. 使用 concurrently 工具)
  • [5. 检查 VSCode 设置](#5. 检查 VSCode 设置)
  • [6. 其他注意事项](#6. 其他注意事项)

1. 临时修改终端编码

在 Windows 系统中,可以通过 chcp 命令临时修改终端的字符编码。默认情况下,Windows 终端使用的是 GBK 编码(代码页 936),而项目通常使用 UTF-8 编码(代码页 65001)。因此,可以在终端中运行以下命令来临时修改编码:

bash 复制代码
chcp 65001

然后运行 Electron 项目。

2. 永久修改终端编码

修改系统区域设置

在 Windows 10 系统中,可以通过修改系统区域设置来永久解决中文乱码问题:

  1. 搜索"区域"。
  2. 依次点击【管理】→ 【更改系统区域设置】。
  3. 勾选【使用 Unicode UTF-8 提供全球语言支持】(Beta 版)。
  4. 重启电脑。

修改注册表

也可以通过修改注册表来永久设置终端的字符编码:

  1. 打开注册表编辑器(regedit)。
  2. 导航到 HKEY_CURRENT_USER\Console%SystemRoot%_system32_cmd.exe。
  3. 新建一个 32 位 DWORD 值,命名为 CodePage,并将值设置为 65001。

3. 修改项目启动脚本

可以在项目的 package.json 文件中修改启动脚本,使其在启动时自动设置终端编码:

bash 复制代码
"scripts": {
  "start": "chcp 65001 && electron ."
}

这样,在运行 npm start 时,终端会自动设置为 UTF-8 编码。

4. 使用 concurrently 工具

如果不想直接修改系统设置,可以使用 concurrently 工具来同时运行多个命令,其中一个命令用于设置终端编码:

安装 concurrently:

bash 复制代码
npm install -D concurrently

修改 package.json 文件:

bash 复制代码
"scripts": {
  "start": "concurrently \"chcp 65001\" \"electron .\""
}

这样在启动项目时,concurrently 会先设置终端编码,然后启动 Electron。

5. 检查 VSCode 设置

如果使用 VSCode 开发 Electron 项目,可能需要检查 VSCode 的终端设置:

打开 VSCode 的设置(Ctrl + , 或 Cmd + ,)。

搜索 terminal.integrated.shellArgs.windows。

添加以下配置:

bash 复制代码
"terminal.integrated.shellArgs.windows": [
  "/k",
  "chcp 65001"
]

这样,VSCode 终端在启动时会自动设置为 UTF-8 编码。

6. 其他注意事项

如果仍然遇到乱码问题,可以尝试检查项目的编码设置,确保代码文件保存为 UTF-8 编码。

在某些情况下,可能需要确保 Electron 的 webPreferences 配置中启用了 nodeIntegration 和 contextIsolation。

相关推荐
heRs BART9 分钟前
spring-boot-starter和spring-boot-starter-web的关联
前端
龙猫里的小梅啊10 分钟前
CSS(七)CSS列表控制
前端·css
浩冉学编程11 分钟前
微信小程序中基于java后端实现官方的文本内容安全识别msgSecCheck
java·前端·安全·微信小程序·小程序·微信公众平台·内容安全审核
李李李勃谦28 分钟前
鸿蒙PC配色方案工具:取色、配色生成与 CSS 导出
前端·css·华为·harmonyos
threelab34 分钟前
Three.js 咖啡杯烟雾效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
Jul1en_1 小时前
Claude 迁移 Codex 工作流迁移与更新
java·服务器·前端·后端·ai编程
Heo1 小时前
14_React 中的更新队列 updateQueue
前端·javascript·面试
前端 贾公子1 小时前
解决浏览器端 globalThis is not defined 报错
前端·javascript·vue.js
宁雨桥1 小时前
前端与AI结合实战分享
前端·人工智能
之歆1 小时前
DAY12_CSS3选择器全攻略 + 盒子新特性完全指南(下)
前端·javascript·css3