语言配置
通过contributes.languages
发布内容配置,你可以配置以下声明式语言特性:
- 启用/关闭注释
- 定义括号
- 自动闭合符号
- 自动环绕符号
- 代码折叠
- 单词匹配
- 缩进规则
语言配置示例中配置JavaScript文件中的编辑功能。本篇指南会详细解释language-configuration.json
中的内容:
!> 注意:如果你的语言配置文件以language-configuration.json
结尾,那么VS Code会帮你添加代码补全和校验功能。
{
"comments": {
"lineComment": "//",
"blockComment": ["/*", "*/"]
},
"brackets": [["{", "}"], ["[", "]"], ["(", ")"]],
"autoClosingPairs": [
{ "open": "{", "close": "}" },
{ "open": "[", "close": "]" },
{ "open": "(", "close": ")" },
{ "open": "'", "close": "'", "notIn": ["string", "comment"] },
{ "open": "\"", "close": "\"", "notIn": ["string"] },
{ "open": "`", "close": "`", "notIn": ["string", "comment"] },
{ "open": "/**", "close": " */", "notIn": ["string"] }
],
"autoCloseBefore": ";:.,=}])>` \n\t",
"surroundingPairs": [
["{", "}"],
["[", "]"],
["(", ")"],
["'", "'"],
["\"", "\""],
["`", "`"]
],
"folding": {
"markers": {
"start": "^\\s*//\\s*#?region\\b",
"end": "^\\s*//\\s*#?endregion\\b"
}
},
"wordPattern": "(-?\\d*\\.\\d\\w*)|([^\\`\\~\\!\\@\\#\\%\\^\\&\\*\\(\\)\\-\\=\\+\\[\\{\\]\\}\\\\\\|\\;\\:\\'\\\"\\,\\.\\<\\>\\/\\?\\s]+)",
"indentationRules": {
"increaseIndentPattern": "^((?!\\/\\/).)*(\\{[^}\"'`]*|\\([^)\"'`]*|\\[[^\\]\"'`]*)$",
"decreaseIndentPattern": "^((?!.*?\\/\\*).*\\*/)?\\s*[\\}\\]].*$"
}
}
启用/关闭注释
VS Code提供了切换注释开关的命令:
- Toggle Line Comment
- Toggle Block Comment
分别来配置comments.lineComment
控制块注释和comments.blockComment
控制行注释。
{
"comments": {
"lineComment": "//",
"blockComment": ["/*", "*/"]
}
}
定义括号
你在VS Code中将鼠标移动到一个括号边上时,VS Code会自动高亮对应的括号。
{
"brackets": [["{", "}"], ["[", "]"], ["(", ")"]]
}
另外,当你运行Go to Bracket或Select to Bracket时,VS Code会自动使用你的定义找到最近、最匹配的括号。
自动闭合符号
当你输入'
时,VS Code会自动帮你补全另一个单引号然后将光标放在引号中间,我们来看看是怎么做的:
{
"autoClosingPairs": [
{ "open": "{", "close": "}" },
{ "open": "[", "close": "]" },
{ "open": "(", "close": ")" },
{ "open": "'", "close": "'", "notIn": ["string", "comment"] },
{ "open": "\"", "close": "\"", "notIn": ["string"] },
{ "open": "`", "close": "`", "notIn": ["string", "comment"] },
{ "open": "/**", "close": " */", "notIn": ["string"] }
]
}
配置notIn
键(key)可以在你需要的时候关闭这个功能。比如你在写下面的代码:
// ES6's Template String
`ES6's Template String`;
此时单引号就不会闭合。
用户可以使用editor.autoClosingQuotes
和editor.autoClosingBrackets
设置自动闭合符号的行为。
在XXX前闭合符号
如果符号的右边有空白,那么VS Code默认会启用符号闭合,所以当你在JSX代码中输入{
时,符号并不会闭合:
const Component = () =>
<div className={>
^ VS Code默认不会闭合此处的括号
</div>
但是你可以用下面的定义覆盖默认行为:
{
"autoCloseBefore": ";:.,=}])>` \n\t"
}
现在如果你在>
前面输入{
,VS Code会自动补全}
。
自动环绕符号
当你选择了一堆文本然后输入左括号时,VS Code会对选中内容外围加上对应的括号。这个功能叫做自动环绕符号,你可以参考下面的代码指定这项功能:
{
"surroundingPairs": [
["{", "}"],
["[", "]"],
["(", ")"],
["'", "'"],
["\"", "\""],
["`", "`"]
]
}
注意用户可以通过editor.autoSurround
设置自动环绕符号的行为。
代码折叠
在VS Code中有三种代码折叠类型:
- 缩进折叠:这是VS Code中默认的缩进行为,当两行内容有着相同的缩进级别时,你就可以看到折叠标记了。
- 语言配置折叠:当VS Code发现
folding.markers
同时定义了start
和end
时,对应区域内就会出现折叠标记。下述配置会对//#region
和//#endregionJSON
区域创建代码折叠标记:
{
"folding": {
"markers": {
"start": "^\\s*//\\s*#?region\\b",
"end": "^\\s*//\\s*#?endregion\\b"
}
}
}
- 语言服务器折叠:语言服务器获取到textDocument/foldingRange请求中的代码折叠列表数据,VS Code之后根据这份列表创建折叠标记。通过语言服务器协议学习更多关于程序性语言特性。
单词匹配
wordPattern
定义了程序语言中单词单位。因此当你使用词语相关的命令,如:Move cursor to word start(Ctrl+Left)或者Move cursor to word end(Ctrl+Right)时,编辑器会根据正则寻找单词边界。
{
"wordPattern": "(-?\\d*\\.\\d\\w*)|([^\\`\\~\\!\\@\\#\\%\\^\\&\\*\\(\\)\\-\\=\\+\\[\\{\\]\\}\\\\\\|\\;\\:\\'\\\"\\,\\.\\<\\>\\/\\?\\s]+)"
}
缩进规则
indentationRules
定义了编辑器应该如何调整当前行或你粘贴、输入、移动的下一行缩进。
{
"indentationRules": {
"increaseIndentPattern": "^((?!\\/\\/).)*(\\{[^}\"'`]*|\\([^)\"'`]*|\\[[^\\]\"'`]*)$",
"decreaseIndentPattern": "^((?!.*?\\/\\*).*\\*/)?\\s*[\\)\\}\\]].*$"
}
}
比如,if (true) {
匹配increasedIndentPattern
,然后如果你在{
后面按下Enter后,编辑器会自动缩进一次,你如代码看起来会像这样:
if (true) {
console.log();
如果没有设置缩进规则,当行尾以开符号结尾时编辑器会左缩进,以闭合符号结尾时右缩进。这里的开闭符号由brackets
定义。
注意editor.formatOnPaste
是由DocumentRangeFormattingEditProvider控制,而不由自动缩进控制。