0

0

VSCode如何自定义键盘映射_修改快捷键有何流程【教程】

紅蓮之龍

紅蓮之龍

发布时间:2026-01-25 19:09:16

|

531人浏览过

|

来源于php中文网

原创

按 Ctrl+Shift+P 执行 Developer: Toggle Developer Tools,在 Console 中按快捷键可查看匹配命令及来源;或用 Preferences: Open Keyboard Shortcuts (JSON) + Ctrl+K Ctrl+S 搜索快捷键,通过“源”列定位 Default/Extension/User 绑定。

vscode如何自定义键盘映射_修改快捷键有何流程【教程】

快捷键冲突时怎么快速定位是哪个扩展或默认键绑定在起作用

Ctrl+Shift+P(Windows/Linux)或 Cmd+Shift+PmacOS)打开命令面板,输入并执行 Developer: Toggle Developer Tools,切换到 Console 标签页;然后在 VSCode 窗口里按下你想查的快捷键(比如 Ctrl+P),控制台会输出类似 KeybindingService#dispatch Ctrl+P 的日志,并附带当前匹配到的命令 ID 和来源(如 workbench.action.quickOpen 来自内置,或 extension.name.command 来自某扩展)。

更直接的方式是:打开命令面板 → 输入 Preferences: Open Keyboard Shortcuts (JSON),再按 Ctrl+K Ctrl+S 打开图形化快捷键界面,在右上角搜索框输入快捷键组合(如 ctrl+shift+p),结果列表会显示所有命中项及其“源”列(DefaultUserExtension)。

如何安全覆盖默认快捷键(比如把 Ctrl+Tab 改成切换编辑器组而非切换标签页)

VSCode 的快捷键优先级是:用户定义 > 扩展贡献 > 默认内置。只要在用户键映射中明确写出新绑定,就会生效。

操作步骤:

  • 打开命令面板 → 执行 Preferences: Open Keyboard Shortcuts (JSON)
  • 在打开的 keybindings.json 文件中添加对象,注意用 key 指定按键组合,command 指定目标命令,when(可选)限定触发上下文
  • 例如想让 Ctrl+Tab 切换编辑器组(而非默认的“最近打开的编辑器”),写入:
[
  {
    "key": "ctrl+tab",
    "command": "workbench.action.quickOpenPreviousEditorInGroup",
    "when": "editorTextFocus"
  }
]

⚠️ 注意:workbench.action.quickOpenPreviousEditorInGroup 是切换组内上一个编辑器,若要循环切换整个编辑器组,应改用 workbench.action.previousEditorInGroup;另外,原生 Ctrl+Tab 行为受 workbench.editor.focusRecentEditorAfterClose 设置影响,建议同步检查该配置是否干扰预期。

为什么改了 keybindings.json 却没生效?常见失效原因

不是语法错误就是上下文冲突。

典型问题包括:

Mulan AI
Mulan AI

画布式AI视频创作平台,轻松制作爆款视频

下载
  • key 值格式不对:必须用小写英文加 + 连接,如 "ctrl+alt+o",不能写成 "Ctrl+Alt+O""CTRL+ALT+O"
  • 命令名拼错或已弃用:比如把 editor.action.formatDocument 写成 editor.formatDocument,VSCode 不报错但不执行
  • when 条件太严格:例如写了 "when": "editorTextFocus && !editorReadonly",但在终端面板按快捷键就自然失效
  • 多个绑定冲突且未设 when 排他:VSCode 会执行第一个匹配项,后写的未必覆盖前写的
  • 扩展自带键绑定被禁用:某些扩展(如 Vim、Emacs Mode)会接管全部快捷键逻辑,此时需先禁用其键绑定,或在 when 中排除其上下文(如 !vim.mode

想让快捷键只在特定语言下生效(比如仅在 Python 文件里 Ctrl+/ 注释代码)

when 表达式配合语言标识符实现,不是靠文件后缀判断。

关键点:

  • VSCode 为每种语言分配唯一 languageId,Python 是 python,TypeScript 是 typescript,YAML 是 yaml —— 全部小写无点号
  • 使用 editorLangId == 'python' 作为 when 条件
  • 如果同时要求光标在编辑器中且非只读,组合写成:editorTextFocus && editorLangId == 'python' && !editorReadonly
  • 示例:让 Ctrl+/ 在 Python 文件中调用 editor.action.blockComment(块注释),其他语言保持默认行注释:
[
  {
    "key": "ctrl+/",
    "command": "editor.action.blockComment",
    "when": "editorTextFocus && editorLangId == 'python'"
  }
]

⚠️ 注意:这个覆盖不会禁用原生 Ctrl+/,只是新增一条更高优先级的规则;若想彻底替换所有语言的行为,需额外加一条通用绑定并设更低优先级条件(如 !editorLangId),但通常不推荐,容易混乱。 实际改键最麻烦的从来不是写 JSON,而是搞清那个“本该触发却静默失败”的快捷键,到底卡在哪一层上下文判断里。多看 when 字段、多试 Ctrl+Shift+P 里的实时搜索,比反复重启 VSCode 有用得多。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

774

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

684

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

767

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

719

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1425

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

571

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

751

2023.08.11

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

45

2026.01.23

热门下载

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

精品课程

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

共48课时 | 7.8万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

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

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