0

0

怎样定制vscode的键盘快捷键映射【教程】

紅蓮之龍

紅蓮之龍

发布时间:2026-01-21 19:59:02

|

279人浏览过

|

来源于php中文网

原创

VS Code 快捷键通过编辑 keybindings.json 实现,需用命令面板打开该文件;每条规则含 key、command 字段,when 为可选上下文条件;覆盖默认键须匹配其 when;跨平台需用 "mac": true 分支。

怎样定制vscode的键盘快捷键映射【教程】

VS Code 的键盘快捷键映射不是靠“教程式点击”完成的,而是通过直接编辑 keybindings.json 文件实现的——图形界面(命令面板 → “Preferences: Open Keyboard Shortcuts (JSON)”)只是它的快捷入口,底层逻辑始终是 JSON 规则匹配。

如何打开并编辑 keybindings.json

最稳妥的方式是用命令面板触发:

  • Ctrl+Shift+P(Windows/Linux)或 Cmd+Shift+PmacOS)打开命令面板
  • 输入并选择 Preferences: Open Keyboard Shortcuts (JSON)
  • VS Code 会打开一个可编辑的 keybindings.json 文件(路径通常为:~/.config/Code/User/keybindings.json%APPDATA%\Code\User\keybindings.json

别手动找文件再用外部编辑器打开——VS Code 会监听该文件变化,但非它启动的编辑可能引发同步冲突或忽略生效逻辑。

添加自定义快捷键的基本结构

每条快捷键是一个对象,必须包含 keycommand 两个字段,when 是可选但高频使用的上下文条件:

[
  {
    "key": "ctrl+alt+f",
    "command": "editor.action.formatDocument",
    "when": "editorTextFocus && !editorReadonly"
  }
]

注意:

a0.dev
a0.dev

专为移动端应用开发设计的AI编程平台

下载
  • key 中的修饰键顺序固定:ctrlshiftaltcmd(macOS),写成 alt+ctrl+f 不生效
  • command 必须是 VS Code 内置命令 ID(可在命令面板里搜索命令名,右键 → “Copy Command ID” 获取)
  • when 表达式决定快捷键是否启用,比如 editorTextFocus 表示光标在编辑器内,terminalFocus 表示焦点在终端——漏写可能导致快捷键在不该触发时静默失败

覆盖默认快捷键的常见陷阱

VS Code 默认快捷键优先级高于用户自定义项,想覆盖必须确保新规则完全匹配原规则的 when 条件,否则旧键仍生效,新键被忽略:

  • 例如想把保存快捷键从 Ctrl+S 改成 Ctrl+Alt+S,只需新增一条;但若想把 Ctrl+S 改绑定到其他命令(如“保存不格式化”),就必须显式写出和原默认项一致的 when,比如:"when": "editorTextFocus && !editorReadonly && !inDebugRepl"
  • Ctrl+K Ctrl+S 打开快捷键 UI,搜索目标命令,点右侧“▶”图标可查看所有绑定(含默认和用户项),带“✓”的是当前生效项,方便比对
  • 多个相同 key + 相同 when 的规则中,后定义的会覆盖前定义的——但建议避免重复定义,直接删掉旧条目更清晰

跨平台快捷键要单独处理

macOS 的 cmd 和 Windows/Linux 的 ctrl 不能自动映射。如果你共享配置,需用平台条件分支:

[
  {
    "key": "ctrl+alt+o",
    "command": "workbench.action.terminal.toggleTerminal",
    "when": "terminalFocus"
  },
  {
    "key": "cmd+alt+o",
    "command": "workbench.action.terminal.toggleTerminal",
    "when": "terminalFocus",
    "mac": true
  }
]

注意:mac 字段是布尔值,不是字符串;且只有 macOS 会读取带 "mac": true 的条目,其他平台自动跳过——这个机制比写两套配置更轻量,也避免误触发。

真正容易出问题的,是 when 条件拼写错误、修饰键顺序错乱、以及没意识到默认快捷键自带复杂上下文约束——这些不会报错,只会让你反复按却没反应。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

416

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

310

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

75

2025.09.10

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1468

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

621

2023.11.24

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.6万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号