Skip to content

vscode

字数
3747 字
阅读时间
17 分钟

cspell

code spell 插件可以帮助你解决 单词拼读错误问题

format on save 设置

json
"editor.formatOnSave": true,
"editor.formatOnSaveMode": "modifications",
"editor.formatOnType": true,
"editor.formatOnPaste": true,

ruff 代替 black flake8

ruff

save on delay 和 auto format on save 同时启用的方法

https://marketplace.visualstudio.com/items?itemName=BdSoftware.format-on-auto-save

不过这个会带来保存速度变慢的问题

层级折叠

ctrl k / ctrl [0-9] 即可 折叠

展开 ctrl k + ctrl j

展开折叠当前 option + cmd + [ / ]

面包屑

  • 面包屑在什么场景下有用
    • 浏览别人仓库代码时
    • 文档很长时(例如 在 markdown 中充当 目录功能,当然你可以直接搜索,但有时你记不住所有的标题名字)
  • vscode开启面包屑
    • 搜索: breadcrumbs.enabled 开启即可
  • 官方文档(包含了详细完整的介绍、相关配置,推荐)
  • 面包屑相关快捷键
    • Ctrl+shift+. 或者 ctrl shif + ;
    • 两个快捷键效果有区别,一个是打开当前,一个是在面包屑的树层级上跳转
    • 基本操作
      • ctrl n / p 或者 上下箭头 进行切换
      • esc 退出面包屑
      • 可以直接输入英文字母进行"高亮搜索",然后按 ctrl n/ p 或上下键 在匹配项中跳转
      • 左右键可以在层级中跳转(很遗憾,好像没有 对应的 ctrl +xx 系列键...
      • space 可以展开 层级
      • enter 跳转到对应的面包屑
    • 所有默认的快捷键可以通过 ctrl k + ctrl s ,然后在快捷键页面中 搜索: breadcrumbs 来获取!
      • ctrl + enter 在新的页面中打开
      • ctrl left 和 right 可以左右跳转(且无视当前层级,默认的 left 和 right 限制在当前文件)
    • 如果你想替换成 vim 的导航方式,可以添加如下快捷键
json
    {
        "key": "ctrl+h",
        "command": "breadcrumbs.focusPrevious",
        "when": "breadcrumbsActive && breadcrumbsVisible"
    },
    {
        "key": "ctrl+j",
        "command": "list.focusDown",
        "when": "breadcrumbsActive && breadcrumbsVisible"
    },
    {
        "key": "ctrl+k",
        "command": "list.focusUp",
        "when": "breadcrumbsActive && breadcrumbsVisible"
    },
    {
        "key": "ctrl+l",
        "command": "breadcrumbs.focusNext",
        "when": "breadcrumbsActive && breadcrumbsVisible"
    }

easy snippet

其他

Consolas, 'Courier New', monospace, 'Microsoft Yahei',  '微软雅黑',

cosolas 这个时候空格跟字母的大小一致 (推荐这个) '微软雅黑' 这个空格只有半个字符 'Courier New' 这个字体很细

  • theme
    • ctrl shift P 选择 theme
    • 插件 one monokai theme ,选择这个,在插件主页有 "set color theme"
  • faq
    • open file in new tab /window 在新窗口中打开
      • user setting中,加入
json
"workbench.editor.enablePreview": false,
  • 加速搜索
    • 忽略搜索文件夹
      • 在设置中搜索"search",找到 ignore_pattern 添加就可以 参考
  • 重新加载窗口
Developer: Reload Window
  • python debug 当前 module launch.json 的配置
    • 需要一个插件: commandvariable
json
{
    // Use IntelliSense to learn about possible attributes.
    // Hover to view descriptions of existing attributes.
    // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
    
        {
          "name": "Python: Module CmdVar",
          "type": "python",
          "request": "launch",
          "console": "integratedTerminal",
          "module": "${command:extension.commandvariable.file.relativeDirDots}.${fileBasenameNoExtension}",
        },
    ]
}
javascript
setting.json
    "files.exclude": {
        "**/.git": true,         // this is a default value
        "**/.DS_Store": true,    // this is a default value
        "**/data": true,    // this is a default value
        
        "**/node_modules": true, // this excludes all folders 
            // named "node_modules" from 
            // the explore tree
            
        // alternative version
        "node_modules": true    // this excludes the folder 
            // only from the root of
            // your workspace 
    }

shortcut快捷键

查看全部快捷键(看这个最好):https―/code.visualstudio.com/shortcuts/keyboard-shortcuts-windows.pdf

  • 也可以 Ctrl K + Ctrl R 打开这个快捷键列表 设置/查找快捷键的方法(需要掌握): 可以在vscode 中 按快捷键 ctrl + K ctrl + S 打开快捷键列表

切换到文件浏览器 ?→ctrl shift E 切换到debug ?→ctrl shift D 切换到Problems ?→ctrl shift M

功能快捷键
打开快捷键设置Ctrl+k + ctrl + s
打开终端Ctrl+`
删除行Ctrl+Shift+K
在当前行下插入新的一行Ctrl+Enter
旁边窗口的快捷键
Debug窗口Ctrl shift+d
多行编辑A方案Alt+shift+鼠标左键 或者 鼠标中键/滚轮键按压
终端切换Ctrl+`
窗口切换Ctrl+1 2
文件切换Alt+1 2
进入编辑器页面(toggle panel)Ctrl+J
进入终端(toggle terminal)Ctrl+`
进入语法错误提示页面Ctrl+shift+M
跳转到下一个错误的地方F8
跳转到定义Ctrl+Click
在侧边文件中显示跳转的定义Ctrl+Alt+Click.
回到最左边的窗口Ctrl+shift+E 之类的 或者 Ctrl+0
ctrl shift alt A ?→add and commit all files (跟滴答清单冲突,所以多加了一个 alt 键)

F12

英文功能快捷键
Go to Definition到定义F12 或者 ctrl+]
Go to Declaration到声明
Go to Type Definition到类型定义
Go to implementations到实现Ctrl+F12
Go to References到引用/提及/参考shift+F12 会出现一个小窗口供你在所有引用中选择, 或者 ctrl+]
Peek Definition瞄一眼定义Alt+F12
open definition to the side在一边打开定义Ctrl+k F12

Ctrl+P

javascript
? 相当于帮助, 提示你可以使用什么命令
## 跳转到某个符号/标题/变量
  • 直接enter: 在原窗口中打开
  • Ctrl+enter: 在侧边窗口中打开
  • vscode cheat sheet 上缺失的快捷键 | 功能 | 命令 | | ------------------- | ------------------ | | 面包屑交互 | Ctrl+shift+. 或者 ctrl shif + ; | | breadcrumb 左右层级 | Ctrl+左右箭头 |

常用命令

功能命令
打开快捷键Preferences: Open Keyboard Shortcuts (可以加 json)
在文件浏览器新建文件File: New File

插件

名称功能
Remote-SSHlinux远程编程
gitlensgit 管理
Git History用来查看git log或则一个文件的git历史,比较不同的分支,commits。
Code Runner支持多种语言的代码的立即执行。
Visual Studio IntelliCode自动代码不全, 类似另外一个付费的插件TabNine
Path Intellisense自动路径补全
Image Preview鼠标悬浮在链接或者装订线(gutter)左边可以预览到图片
better comments使注释有人性化的高亮显示 * ! TODO @ // 都会有不同的颜色,可以用 #+符号 或者行开头使用
Open in application右键在默认应用中打开,然而不能ctrl + click打开
draw.iovscode里画流程图
code runner一键运行代码Ctrl+Alt+N 终止Ctrl+Alt+M
Excel Viewer用 更好的格式 看表格 csv 文件
File Utils提供命令行(以File: 开头)的方式来快速移动,删除,重命名文件

需求:

  1. 类似 grep -r / remnote search 的整个仓库内容(而不是文件名) 模糊查找插件
  2. vscode 自带的 ctrl shift F缺点
    1. 只能 alt enter 搜索,而不能在下拉框中搜索
    2. 似乎没办法 fuzzy search,只能正则表达式匹配... get.{0,8}put

目前的解决方案

  1. 文档内搜索
    1. 全文搜索
      1. fuzzy search
      2. vim
    2. 标题搜索 Ctrl shift O
  2. 整个仓库搜索
    1. 全文搜索
      1. ctrl shift F + 正则表达式
      2. fzf search
    2. 标题搜索 ctrl + T

2022-1-26:

  • 花了2小时... 看了一圈,很有可能要自己写插件,可以参考 fuzzy go to line 的代码
  • 太难了,我放弃了..

尝试的插件列表

  • fzf fuzzy quick open GOOD 唯一贴合自己需求的,但是用起来还是不太爽
    • fzf: add workspace 第一次使用可能需要设置
    • fzf: search using fzf and rg
    • 依赖于 fzf 和 rg,不过我自己测试,其实就是唤起终端进行搜索,但搜索结果有时无法跳转回 vscode 编辑页面,不知道为什么...
  • jaco / fuzzy search : search: Fuzzy outline GOOD 还能用的...
    • 可以在当前文档中搜索,并将结果实时展示出来(而不需要像vim那样一个个跳转) 还是挺实用的,可惜没有真的做到"fuzzy",也没有做到在整个仓库中搜索|
  • fuzzy go to line: https://github.com/kylqin/vscode-fuzzy-goto-line
    • 类似上面的插件,也只能在当前文件中搜索,而且也没有真正 fuzzy
  • search everywhere
    • 每次重启vscode的时候,需要 scan file ,花了我28秒(大量markdown文件),而且按 ctrl alt p的时候非常卡
  • findItfaster
    • 可惜只能用于终端... 而且需要安装 fzf ,有其他很多类似的插件,有可能只能在linux上用,window用不了,或者安装比较麻烦
  • Incremental Grep
    • 有bug,使用的时候报错 fatal: ambiguous argument '': unknown revision or path no int the working tree
  • vscode-git-grep
    • 优点: 目前唯一一个可以全文搜索的,并且在下拉框中显示结果,但其实还不如 ctrl shift F 里头的正则表达式..
    • 缺点: 只能在git中检索, 没有即时搜索,每次都需要先确认
    • bug: 不支持正则表达式
  • rg|ripgrep (不是一个插件) ,只是很多插件中提到要先下载这个...
    • rg "get.{0,8}put"

有没有可能在 vscode-neovim 中安装 fzf 的插件呢? 貌似不行...

搜索关键词 - fuzzy search grep fzf

neovim

  • 复制到剪贴板
    • 将下面的内容复制到 C:\Users\USERNAME\AppData\Local\nvim\init.vim (这个AppData可能是隐藏文件夹)
    • 最后重启 vscode
python
set clipboard+=unnamedplus
  • 路过折叠块时不展开折叠
python
nmap j gj
nmap k gk

FAQ

  • 指定区域 fold
    • Python #region or **# region **#endregion or # endregion
    • To fold and unfold only the regions defined by markers use:
      • Fold Marker Regions (Ctrl+K Ctrl+8) folds all marker regions.
      • Unfold Marker Regions (Ctrl+K Ctrl+9) unfolds all marker regions
    • " https://diigo.com/0jnxiz
  • 在新标签页中打开文件
    • 单击文件名是预览(这时会替换当前的页面)
    • 双击文件名则是在新标签页中打开
    • 如果不想要这个功能的话:
    • 给你配置settings.json里加一条:
    • "workbench.editor.enablePreview": false,
    • "workbench.editor.enablePreviewFromQuickOpen": false,
  • 打开setting.json
    • 命令行里直接输入 Open workspace/ setting(json) /user settting
  • vscode各种bug?
      1. vscode 加载插件需要时间
      1. vscode更改设置需要时间(比如切换python的interpreter)
      1. 有时候重启vscode就好了
  • winddow下 vscode cmd改为cmder
  • Ctrl + space 解决冲突
    • 通常自动补全都是自动生成的,不需要按Ctrl space,不过ctrl space 会被window和搜狗占用
    • 2个方案
      1. 修改window对ctrl space 的占用:设置-高级键盘设置-输入语言热键-把Ctrl+space改成其他的,之后重启电脑
      1. ctrl +k ctrl +s 修改快捷键为 alt + /
  • 一个shortcut执行2个指令的方法
  • 一个shortcut执行正操作和反操作
      1. 法1:设定不同的“when”,比如toggle pane
  • vscode 无法连接远程服务器
    • 2 关闭 服务器上 所有 vscode 的进程 (优先这个,不行的话,就下面的步骤)
    • 1 删除 服务器上的 .vscode-server 重新连接(会重装)
  • drag and drop 不work(服务器拉到本地的操作不成功)
  • Missing or invalid credentials.
    • Error: connect ECONNREFUSED /run/user/2078/vscode-git-29959dbc73.sock
    • 方法1: 使用 xshell 连接
    • 方法2: 推荐
      • You are trying to use git from a terminal in vscode. The problem comes from the authentication handler of vscode. To solve the problem:
        • Open vscode File > Preferences > Settings
        • Search for git.terminalAuthentication
        • Uncheck the option
      • You have to re-open the terminal to make it work.

其他

markdown

  • 快捷键(自己的设置) - ctrl shift 6 ?→toggle code block - ctrl shift 2/3/4 ?→toggle header - ctrl shift s ?→checkboxes - ctrl shift 7/8 ?→number / bullet list/points
  • markdown preview theme 预览主题

todo 功能

我用alt + enter 来toggle checkbox (create/delete) 用 alt + c 来 toggle checkbox done (done/undo)

插件: markdown checkbox + 自定义快捷键

快捷键 oem_3是什么 中文键盘下就是符号:`, 在Esc键的下面。类似的 括号,冒号之类是oem_数字键

The OEM keys are the keys that vary with local keyboards. Where the US keyboard has brackets and braces, german keyboards have umlauts.

They are called "OEM" because the Original Equipment Manufacturer (of the keyboard) was responsible for defining their functionality.

贡献者

文件历史