vscode 配置及插件推荐

前置知识

首先说明一下,vscode 为我们提供了两种设置方式:

  • User Settings(用户设置):全局设置,对任意一个运行的 VS Code 都会起作用。
  • Workspace Settings(项目设置):只对当前项目的设置。

:Workspace Settings 会覆盖 User Settings。

打开用户设置和项目设置的方法如下:

  • On Windows/Linux - File > Preferences > Settings
  • On macOS - Code > Preferences > Settings

或直接通过命令行面板(Ctrl+Shift+P)输入 open settings 进行调出。

vscode 中的 设置选项 都配置在一个 settings.json 文件中。
其中,用户设置(User Settings) 的路径为:

  • Windows %APPDATA%\Code\User\settings.json
  • macOS $HOME/Library/Application Support/Code/User/settings.json
  • Linux $HOME/.config/Code/User/settings.json

项目设置(Workspace Settings) 的路径为:根目录下的.vscode中。

以下是博主的通用配置:

{
  //  - onWindowChange: A dirty file is automatically saved when the window loses focus
  // "files.autoSave": "onFocusChange",
  // Controls the font size in pixels.
  "editor.fontSize": 14,
  // The number of spaces a tab is equal to. This setting is overridden based on the file contents when `editor.detectIndentation` is on.
  "editor.tabSize": 4,
  // Configure glob patterns for excluding files and folders. For example, the files explorer decides which files and folders to show or hide based on this setting. Read more about glob patterns [here](https://code.visualstudio.com/docs/editor/codebasics#_advanced-search-options).
  "files.exclude": {
    "**/.git": true,
    "**/.svn": true,
    "**/.hg": true,
    "**/CVS": true,
    "**/.DS_Store": true
  },
  "editor.quickSuggestions": {
    "other": true,
    "comments": true,
    "strings": true
  },
}

必备插件

Settings Sync

vscode 多设备同步工具,借助 Github GIST 支持设置文件(settings.json),按键映射文件(keybindings.json), Launch File,Snippets Folder,VSCode扩展及配置,项目文件夹等的同步。

使用方法:

  • 上传: Shift + Alt + U (Sync: Update / Upload Settings)
  • 下载: Shift + Alt + D (Sync: Download Settings)

配置详细步骤:

  1. 首先在 vscode 中安装 Settings Sync
  2. 进入 github / Settings / Developer settings / Personal access tokens / Generate New Token
Generate New Token

Select Gist From Scopes
Get an Access Token

按上文步骤操作后,最后就可以得到一个 Access Token。把这个 Access Token 记录下来,后续在其他设备上上传配置时,需要使用到。

  1. 上传配置文件
     • 命令面板输入Sync : Update / Upload Settings(或快捷键Shift + Alt + U
     • 输入 Access Token,创建 gists,进行配置上传
     • 上传成功后,会返回一个 Gist ID。保存该 Gist ID,下次其他设备需要下载配置时需要用到。
上传配置文件

:上传的配置文件可以在以下网址进行查看:https://gist.github.com/{your_userName}/{gist_id}

  1. 下载/同步配置文件
     • 命令面板输入Sync : Download Settings(或快捷键Shift + Alt + D
     • 输入 Access Token
     • 输入 Gist ID
     • 下载完成
    下载/同步配置文件

通用插件

vim 插件扩展:VSCodeVim

注:VSCodeVim 不支持 vim 脚本加载,因此无法使用 .vimrc.vim插件进行配置。只能通过手动复制到 SettingsEmulated plugins.

设置VSCodeVim 完整的选项支持列表可以在 vscode 的扩展菜单中的 Contributions 标签查看。下面是博主自己的常用配置:

{
  "vim.leader": "<space>",
  "vim.hlsearch": true,
  "vim.ignorecase": true,
  "vim.smartcase": true,
  "vim.incsearch": true,
  "vim.useSystemClipboard": true,
  // do override vscode default ctrl operations
  "vim.useCtrlKeys": true,
  //key handled by vscode
  "vim.handleKeys": {
    // "<C-a>": false,
    "<C-f>": false
  },
  "vim.normalModeKeyBindingsNonRecursive": [
    {
      "before": ["<leader>", "q"],
      "commands": ["workbench.action.closeActiveEditor"]
    },
    {
      "before": ["<leader>", "w"],
      "commands": ["workbench.action.files.save"]
    },
    {
      "before": ["<leader>", "c", "c"],
      "commands": ["editor.action.addCommentLine"]
    },
    {
      "before": ["<leader>", "c", "u"],
      "commands": ["editor.action.removeCommentLine"]
    },
    {
      "before": ["<leader>", "f", "m"],
      "commands": ["editor.action.format"]
    },
    {
      "before": ["<C-a>"],
      "after": ["g", "g", "v", "G"]
    },
    {
      "before": ["<C-x>"],
      "commands": ["editor.action.clipboardCutAction"]
    }
  ],
  "vim.visualModeKeyBindings": [
    {
      "before": ["<C-x>"],
      "after": ["\"", "+", "d"]
    },
    {
      "before": ["<leader>", "c", "c"],
      "commands": ["editor.action.addCommentLine"]
    },
    {
      "before": ["<leader>", "c", "u"],
      "commands": ["editor.action.removeCommentLine"]
    },
    {
      "before": ["<leader>", "f", "m"],
      //using prettier
      "commands": ["editor.action.formatSelection"]
    }
  ],
  //easymotion
  "vim.easymotion": true,
  //sneak disable,cuz i want the default s function
  "vim.sneak": false,
  "vim.sneakUseIgnorecaseAndSmartcase": true,
  //surround
  "vim.surround": true,
}

下面介绍下一些相对有用的配置选项:

  • 按键映射:可以通过配置 "vim.insertModeKeyBindings"/"vim.normalModeKeyBindings"/"vim.visualModeKeyBindings"/"vim.insertModeKeyBindingsNonRecursive"/"normalModeKeyBindingsNonRecursive"/"visualModeKeyBindingsNonRecursive"对插入模式/正常模式/可视模式下进行自定义按键重映射。
    xxxNonRecursive表示不进行递归调用。比如,正常模式下(vim.normalModeKeyBindings),将j映射为gj,那么当按下j时,gj就会被触发,此时由于又触发了j键,因此又会触发新一轮的gj,一直如此反复递归进行。而使用 Non-recursive 非递归模式就可以避免这种自动递归扩展。

VSCodeVim 的配置文件加载顺序如下:

  1. :set {setting}
  2. vim.{setting} from user/workspace settings.
  3. VS Code settings
  4. VSCodeVim default values

我们知道,在 vim 中,有各种各样的插件可以为我们提供丰富的功能。而 VSCodeVim 中,也为我们提供了一些模拟插件(Emulated Plugins):

  • vim-easymotion:基于 vim-easymotion 的模拟插件,我们只需启动该插件即可:
//使能 easymotion
"vim.easymotion":true,

其具体使用方法请查看:vim-easymotion。博主常用的使用方法如下:

Motion Command Description
<leader><leader> s <char> 全文查找字符
<leader><leader> w 查找当前光标后面的单词首字母
<leader><leader> b 查找当前光标前面的单词首字母
//使能 vim.surround 插件
"vim.surround":true,
  • vim-commentary:类似 vim-commentary,但使用 vscode 内置的 Toggle Line CommentToggle Block Comment特性。

使用方法如下:

Command Description
gc 注释切换 (eg:gcc单行注释切换,gc2j当前行和下两行注释切换)
gC 块注释切换(eg:gCi{ 大括号内容注释切换
  • vim-sneak:基于 vim-sneak,提供基于两个字母随处跳转功能。
    配置如下:
"vim.sneak":true,
"vim.sneakUseIgnorecaseAndSmartcase":true,

使用方法如下:

Motion Command Description
s<char><char> 向后寻找第一次出现<char><char>的位置
S<char><char> 向后寻找第一次出现<char><char>的位置
<operator>z<char><char> 向后寻找第一次出现符合<operator><char><char>的位置
<operator>Z<char><char> 向前寻找第一次出现符合<operator><char><char>的位置

:对于有<operator>的移动,使用z代替s,因为s已经被插件 vim-surround 占据了。

  • 输入法切换问题:vim 通常都处于 normal 模式和 insert 模式切换状态。如果当前处于 insert 模式,且输入法为中文输入。那么在退出 insert 模式(按下 <esc>)后,输入法状态仍然为中文输入,则此时在 normal 模式下,仍然处于中文输出状态,无法进行正常的 vim 操作,仍需手动切换为英文输入法才可操作 normal 模式。 VSCodeVim 官方已考虑到这个问题,并提供了解决方法,如下所示:
  1. 首先系统需要安装一个第三方输入法切换程序:im-select
  2. 找到默认输入法键值。
    对于 Mac 系统:先切换为英文输入法,然后运行/<path-to-im-select-installation>/im-select输出默认输入法键值。下表列出 MacOS 常见的英文键值布局:
Key Description
com.apple.keylayout.US U.S.
com.apple.keylayout.ABC ABC
com.apple.keylayout.British British
com.apple.keylayout.Irish Irish
com.apple.keylayout.Australian Australian
com.apple.keylayout.Dvorak Dvorak
com.apple.keylayout.Colemak Colemak

对于 Windows 系统:输入法键值获取详情请参考 im-select guide 。通常来说,如果你的键盘布局为 en_US,那么键盘输入法键值为1033(建议添加该键盘布局为默认输入法)。你也可以通过 Locale-codes 页面查找你的 locale ID,LCID Decimal列就是 locale ID 值。

  1. 配置vim.autoSwitchInputMethod:
  • Mac 系统:
"vim.autoSwitchInputMethod.enable": true,
//默认键盘布局
"vim.autoSwitchInputMethod.defaultIM": "com.apple.keylayout.US",
"vim.autoSwitchInputMethod.obtainIMCmd": "/usr/local/bin/im-select",
"vim.autoSwitchInputMethod.switchIMCmd": "/usr/local/bin/im-select {im}"
  • Windows 系统:
"vim.autoSwitchInputMethod.enable": true,
"vim.autoSwitchInputMethod.defaultIM": "1033",
"vim.autoSwitchInputMethod.obtainIMCmd": "D:\\apps\\im-select.exe",
"vim.autoSwitchInputMethod.switchIMCmd": "D:\\apps\\im-select.exe {im}"

上述配置的选项{im}是一个指代切换输入法的命令行选项。

代码运行:Code Runner

Code Runner 可以执行多种语言代码:C, C++, Java, JavaScript, PHP, Python, Perl, Perl 6, Ruby, Go, Lua, Groovy, PowerShell, BAT/CMD, BASH/SH, F# Script, F# (.NET Core), C# Script, C# (.NET Core), VBScript, TypeScript, CoffeeScript, Scala, Swift, Julia, Crystal, OCaml Script, R, AppleScript, Elixir, Visual Basic .NET, Clojure, Haxe, Objective-C, Rust, Racket, AutoHotkey, AutoIt, Kotlin, Dart, Free Pascal, Haskell, Nim, D, Lisp 和 自定义命令。

使用方法:

  • 运行代码
     ● 直接点击文件右上角三角运行符号
     ● 使用快捷键:Ctrl+Alt+N
     ● 选中要运行的代码片段,点击右键选择Run Code
  • 停止运行
     ● 使用快捷键:Ctrl+Alt+M
     ● 右击输出面板,选择Stop Code Run
  • 指定使用特定语言进行运行:使用快捷键Ctrl+Alt+J或者按F1键后输入/选择Run By Language,最后输入要运行的语言,如php, javascript, bat, shellscript...
    :使用这种方法同时结合选中代码部分进行执行,可以很方便地在同一个文件内执行多种不同的语言代码。
code runner
  • 运行自定义命令:使用快捷键Ctrl+Alt+K,或者按F1键后输入/选择Run Custom Command。自定义命令配置结构如下所示:
{
    "code-runner.customCommand": "echo Hello"
}

配置:默认情况下,请确保各类语言的执行器配置在全局环境变量中。你也可以通过配置code-runner.executorMap设置执行器路径:

{
    "code-runner.executorMap": {
        "javascript": "node",
        "php": "C:\\php\\php.exe",
        "python": "python",
        "perl": "perl",
        "ruby": "C:\\Ruby23-x64\\bin\\ruby.exe",
        "go": "go run",
        "html": "\"C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe\"",
        "java": "cd $dir && javac $fileName && java $fileNameWithoutExt",
        "c": "cd $dir && gcc $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt"
    }
}

下表是 Code Runner 支持的自定义参数:

Supported customized parameters Description
$workspaceRoot 当前工程目录路径
$dir 要运行的代码文件所在的目录
$dirWithoutTrailingSlash 要运行的代码文件所在的目录(不带尾后斜杆)
$fullFileName 要运行的代码文件全路径
$fileName 要运行的代码文件名称
$fileNameWithoutExt 要运行的代码文件名称(不带后缀名)
$driveLetter 要运行的代码文件所在盘符(只用于 Windows 系统)
$pythonPath Python 解释器路径

下面是本人的配置:

{
    "code-runner.clearPreviousOutput": true,
    "code-runner.saveAllFilesBeforeRun": true,
    "code-runner.saveFileBeforeRun": true,
    "code-runner.preserveFocus": true,
    "code-runner.ignoreSelection":false,
    //top right execute icon
    "code-runner.showRunIconInEditorTitleMenu":true,
}

Bracket Pair Colorizer 2

用不同的颜色区分大括号,该插件是 Bracket Pair Colorizer 的升级版本,使用同一套括号解析引擎,但极大增加了配置速度及准确性。

本人配置如下:

{
    "bracket-pair-colorizer-2.forceUniqueOpeningColor":true,
    "bracket-pair-colorizer-2.forceIterationColorCycle":true,
    "bracket-pair-colorizer-2.colorMode":"Consecutive",
    "editor.matchBrackets":false,
    "bracket-pair-colorizer-2.highlightActiveScope":true,
    "bracket-pair-colorizer-2.activeScopeCSS":[
        "borderStyle : solid",
        "borderWidth : 1px",
        "borderColor : {color}; opacity: 0.5",
        "backgroundColor:{color}"
    ],
    "bracket-pair-colorizer-2.showBracketsInGutter": true,
    "bracket-pair-colorizer-2.showHorizontalScopeLine": false,
    "bracket-pair-colorizer-2.showVerticalScopeLine": true,
}

TODO Highlight

高亮显示 TODOs / FIXMEs 的地方。

本人配置如下:

{
    "todohighlight.isEnable": true,
    "todohighlight.isCaseSensitive": true,
    "todohighlight.include": [
        "**/*.js",
        "**/*.jsx",
        "**/*.ts",
        "**/*.tsx",
        "**/*.html",
        "**/*.php",
        "**/*.css",
        "**/*.scss",
        "**/*.py",
        "**/*.java",
        "**/*.kt",
        "**/*.h",
        "**/*.c",
        "**/*.cpp",
    ],
    "todohighlight.exclude": [
        "**/node_modules/**",
        "**/bower_components/**",
        "**/dist/**",
        "**/build/**",
        "**/.vscode/**",
        "**/.github/**",
        "**/_output/**",
        "**/*.min.*",
        "**/*.map",
        "**/.next/**"
    ],
    "todohighlight.maxFilesForSearch": 5120,
    "todohighlight.toggleURI": false,
}

TODO Highlight 内置命令如下:

  • Toggle highlight:打开/关闭高亮功能
  • List highlighted annotations:在输出控制台中列出所有 TODO 信息

vscode-icons

vscode 资源树目录加上图标

配置如下:

{
    "workbench.iconTheme": "vscode-icons",
}

Path Intellisense

对本地文件的智能提示,自动补全文件名

Window 系统需在 keybindings.json 中添加如下配置:

{ "key": ".", "command": "" }

:keybindings.json 打开方式如下图所示:

keybindings.json

Java 环境搭建

VSCode搭建Java开发运行环境

前端

Auto Close Tag

自动补全标签

本人配置如下:

{
    "auto-close-tag.enableAutoCloseTag": true,
    "auto-close-tag.enableAutoCloseSelfClosingTag": true,
    "auto-close-tag.activationOnLanguage": [
        "xml",
        "php",
        "blade",
        "ejs",
        "jinja",
        "javascript",
        "javascriptreact",
        "typescript",
        "typescriptreact",
        "plaintext",
        "markdown",
        "vue",
        "liquid",
        "erb",
        "lang-cfml",
        "cfml",
        "HTML (Eex)"
    ]
}

Auto Rename Tag

自动重命名 HTML/XML 匹配标签

Auto Close TagAuto Rename Tag 一起食用味道更佳哟。

ESLint

ESLint中文站点)是一个开源的 JavaScript 代码检查工具,使用 Node.js 编写,由 Nicholas C. Zakas 于 2013 年 6 月创建。ESLint 的初衷是为了让程序员可以创建自己的检测规则,使其可以在编码的过程中发现问题而不是在执行的过程中。ESLint 的所有规则都被设计成可插入的,为了方便使用,ESLint 内置了一些规则,在这基础上也可以增加自定义规则。

要在 vscode 中集成 ESLint,需要进行如下步骤:

  • 首先需要在当前工程下安装 ESLint(npm install eslint),或者直接全局安装 ESLint(npm install -g eslint)。
  • 对 ESLint 执行初始化:
     ▶ 全局安装,命令行直接执行:eslint --init
     ▶ 局部安装,命令行直接运行:Windows 系统:.\node_modules\.bin\eslint --init,Linux 和 Mac 系统:./node_modules/.bin/eslint --init。命令执行完成后会在项目根目录下生成一个.eslintrc.js文件;
  • vscode 中安装 ESLint 插件;
  • 配置 ESLint:
{
    "eslint.enable": true,
    "eslint.options": {
        "configFile": "C:/Users/10417/.eslintrc.js",
        "eslint.autoFixOnSave": true,
        "eslint.validate": [
            "javascript",
            "javascriptreact",
            "html",
            "jsx",
            "vue",
            {
                "language": "html",
                "autoFix": true
            }
        ]
    }
}

Prettier

代码格式化插件,支持 JavaScript / TypeScript / CSS

使用方法

  • 格式化文档:CMD/Ctrl + Shift + P -> Format Document
  • 格式化选中:CMD/Ctrl + Shift + P -> Format Selection

*配置如下

{
  "editor.formatOnSave": true,
  "prettier.singleQuote": true,
}

Markdown

Markdown Preview Enhanced

Markdown Preview Enhanced 是一款为 Atom 以及 Visual Studio Code 编辑器编写的 超级强大的 Markdown 插件。 这款插件意在让你拥有飘逸的 Markdown 写作体验。

运行方法:快捷键Ctrl-K-V,或直接点击右上角分页符号:

run markdown

可以通过自己配置 css 来定制 markdown 页面样式,详情请查看:customize-css

最后附上全部的配置文件:settings.json

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容

  • Sublime Text:一款具有代码高亮、语法提示、自动完成且反应快速的编辑器软件,不仅具有华丽的界面,还支持插...
    xiaotao123阅读 9,493评论 0 27
  • 工欲善其事必先利其器,软件工程师每天打交道最多的可能就是编辑器了。入行几年来,先后折腾过的编辑器有 EditPlu...
    王仕军阅读 5,004评论 2 33
  • 前言 相信对于很多写代码的小伙伴来说,对于开发编辑器都不会陌生,什么editplus,dw,webstorm,hu...
    itclanCoder阅读 1,612评论 1 8
  • 六和敬 身和而同住 口和而无诤 意和而同悦 戒和而同修 利和而同均 见和而同解
    初小湄阅读 219评论 0 0
  • 看完《寻梦环游记》后,心情是夹杂喜悦和悲伤的。口碑极佳的影片,好的影片总是看一遍不够。电影中的故事真好,有...
    安静的星期天阅读 535评论 1 0