VSCode代码片段支持变量(如$1、$TM_FILENAME_BASE)和变量转换(${VAR/regex/replacement/flags}),可智能生成文件名、接口名等;常用内置变量包括光标定位、文件路径、剪贴板内容等,转换语法支持正则替换与大小写处理,大幅提升模板灵活性。

VSCode 的代码片段(Snippets)支持变量(如 $1、$TM_FILENAME_BASE)和变量转换(${VAR/regex/replacement/flags}),合理使用能极大提升模板灵活性,尤其适合生成文件名、接口名、组件名等带规则的代码结构。
这些变量无需定义,直接在 snippet body 或 prefix 中使用:
$1, $2 —— 光标跳转位置,数字越小越先被聚焦$0 —— 最终光标停留位置(退出 snippet 后的落点)$TM_FILENAME —— 当前文件名(含扩展名),如 user.service.ts
$TM_FILENAME_BASE —— 文件名不含扩展名,如 user.service
$TM_FILEPATH —— 绝对路径,如 /src/app/user/user.service.ts
$TM_DIRECTORY —— 文件所在目录路径$CLIPBOARD —— 系统剪贴板内容(需启用 "editor.suggest.snippetsPreventQuickSuggestions": false 才能生效)转换格式为 ${VAR/regex/replacement/flags},其中 VAR 是任意变量(包括嵌套转换),regex 是 JavaScript 风格正则表达式(注意:不支持 lookbehind/lookahead),replacement 支持 $1, $2 捕获组引用,flags 常用 g(全局)、i(忽略大小写)。
${TM_FILENAME_BASE/(.*)/${1:/capitalize}/} → User.service → UserService(注意:仅首字母大写,需配合多次转换)${TM_FILENAME_BASE/[-_](.)/${1:/upcase}/g} → user-service → userService
${TM_FILENAME_BASE/.service$//}/${TM_FILENAME_BASE/^(.*).service$/${1:/camelcase}/}(推荐拆成两步更清晰)${TM_FILENAME_BASE/.ts$//} 先去扩展名,再套一层:${1/(^|[-_])([a-z])/${2:/upcase}/g} → user-list-item → UserListItem
假设当前文件是 auth.service.ts,想自动补全类名 AuthService、构造函数注入 private http: HttpClient、并导出常量 AUTH_SERVICE_TOKEN:
{
"Angular Service Template": {
"prefix": "ngs",
"body": [
"import { Injectable, InjectionToken } from '@angular/core';",
"import { HttpClient } from '@angular/common/http';",
"",
"export const ${TM_FILENAME_BASE/(.*)\.service$/${1:/pascalcase}/}_TOKEN = new InjectionToken('${TM_FILENAME_BASE/(.*)\.service$/${1:/pascalcase}/}');",
"",
"@Injectable({",
" providedIn: 'root'",
"})",
"export class ${TM_FILENAME_BASE/(.*)\.service$/${1:/pascalcase}/} {",
" constructor(private http: HttpClient) { }",
"}"
],
"description": "Generate Angular service with token and pascal-cased name"
}
}关键点:${1:/pascalcase} 是 VSCode 内置转换(5.0+ 支持),比手动正则更可靠;若版本低,可用 ${1/(^|[-_])([a-z])/${2:/upcase}/g} 替代。
变量转换容易出错,常见问题有:
^ 和 $ 匹配整个字符串开头结尾(VSCode 实际执行的是 .replace(),非 .test()),应确保模式覆盖目标部分${TM_FILENAME_BASE/.*/MATCHED/}
// DEBUG: $TM_FILENAME_BASE = ${TM_FILENAME_BASE} 查看原始值基本上就这些。用好变量和转换,能让 snippet 从“填空题”升级为“智能生成器”。
以上就是VSCode中的代码片段变量与转换的高级用法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号