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。

相关推荐
风清云淡_A2 分钟前
【Flutter3.8x】flutter从入门到实战基础教程(四):自定义实现一个自增的StatefulWidget组件
前端·flutter
curdcv_po4 分钟前
🔥 Three.js 一个项目用到:轨道控制器、动画与GUI交互
前端
琹箐5 分钟前
CSS font-weight:500不生效
前端·css
代码的余温25 分钟前
React核心:组件化与虚拟DOM揭秘
前端·react.js·前端框架
小螺号dididi吹26 分钟前
【React】状态管理
前端·javascript·react.js
代码的余温30 分钟前
React Refs:直接操作DOM的终极指南
前端·javascript·react.js
一只小风华~41 分钟前
JavaScript 定时器
开发语言·前端·javascript·vue.js·web
朝阳391 小时前
浏览器【详解】requestIdleCallback(浏览器空闲时执行)
前端·浏览器
典学长编程1 小时前
前端开发(HTML,CSS,VUE,JS)从入门到精通!第二天(CSS)
前端·javascript·css·html
Chase_______2 小时前
JavaWeb笔记2-JavaScript&Vue&Ajax
开发语言·javascript·vue.js