首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
如何在VSCode自定义代码片段(Snippets)中自动插入当前的日期和时间

如何在VSCode自定义代码片段(Snippets)中自动插入当前的日期和时间

热心网友
85
转载
2026-05-03

如何在VSCode自定义代码片段(Snippets)中自动插入当前的日期和时间

如何在VSCode自定义代码片段(Snippets)中自动插入当前的日期和时间

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

VSCode代码片段里怎么用$CURRENT_YEAR这类变量

先说一个核心事实:VSCode本身并不支持像$TODAY$NOW这样的动态时间变量。所有以$开头的占位符,无论是$1还是$TM_FILENAME,本质上都是静态的——它们只在代码片段被触发的那一刻计算一次,之后就固定不变了。时间变量也不例外,它们属于“只读上下文变量”。

截至目前(VSCode v1.90),编辑器内置的时间变量只有6个:$CURRENT_YEAR$CURRENT_MONTH$CURRENT_DATE$CURRENT_HOUR$CURRENT_MINUTE$CURRENT_SECOND。关键在于,它们**全部只在片段插入的瞬间被计算,之后无法实时刷新**。

这里有个常见的理解误区:以为$CURRENT_DATE能像某些模板引擎一样,随着系统时间自动更新。实际上,它只是插入那一刻的一个YYYY-MM-DD格式的字符串快照,与后续的系统时钟变化毫无关系。

正确写法:组合内置变量拼出完整时间格式

好消息是,虽然变量是静态的,但VSCode允许你自由地组合它们。直接用连字符、斜杠或冒号等符号把多个变量拼接起来就行,完全不需要额外的函数或复杂的转义操作。

  • "date": "$CURRENT_YEAR-$CURRENT_MONTH-$CURRENT_DATE" → 输出结果类似 2024-06-15
  • "datetime": "$CURRENT_YEAR-$CURRENT_MONTH-$CURRENT_DATE $CURRENT_HOUR:$CURRENT_MINUTE:$CURRENT_SECOND" → 输出结果类似 2024-06-15 14:23:07
  • "iso": "$CURRENT_YEAR-$CURRENT_MONTH-$CURRENT_DATET$CURRENT_HOUR:$CURRENT_MINUTE:$CURRENT_SECOND" → 输出结果类似 2024-06-15T14:23:07

需要警惕的是格式细节:$CURRENT_HOUR采用24小时制,且不会自动补零;$CURRENT_MONTH$CURRENT_DATE同样如此。所以,你完全可能得到2024-6-5这样的输出。如果你严格要求0605这样的两位数格式,抱歉,VSCode原生片段功能办不到,必须借助插件或外部脚本。

想自动补零或加毫秒?必须用插件或自定义命令

原生的代码片段机制能力有限,它既不能进行字符串格式化(比如调用类似padStart(2, '0')的方法),也无法直接执行Ja vaScript代码。因此,想要实现2024-06-15 14:02:07.123这种带毫秒、且月份日期都补零的完美格式,只有两条路可走:

  • 安装插件:例如Insert Date String(由jsynowiec开发)这类插件,可以通过快捷键插入多种预设好的、格式规整的日期时间。但它的局限在于,无法直接嵌入到你的自定义代码片段中自动触发。
  • 编写自定义命令:这是一条更底层的路径。你需要在package.json中注册一个命令,利用VSCode的API(如new Date().toISOString())获取精确时间,再通过editor.insert()写入编辑器。然后,你可以在代码片段里预留位置并绑定快捷键来调用这个命令。不过,这本质上已经超越了片段本身的功能,是在用命令系统来弥补片段的不足。

顺便提一句,别在${TM_SELECTED_TEXT/.../}这类转换器里打时间变量的主意。因为在你尝试用正则处理它们之前,这些变量早就被展开成固定的日期字符串了,根本无法进行二次加工。

实际配置示例:一个带注释头的TypeScript片段

理论说了这么多,来看个实际的例子。把下面这段JSON配置保存为typescript.json文件,然后放到对应的用户片段目录里:

{
  "file header with datetime": {
    "prefix": "hdr",
    "body": [
      "/**",
      " * @file ${1:filename}",
      " * @created $CURRENT_YEAR-$CURRENT_MONTH-$CURRENT_DATE $CURRENT_HOUR:$CURRENT_MINUTE",
      " * @author ${2:Your Name}",
      " */",
      "",
      "${0:// code here}"
    ],
    "description": "Insert file header with current date and time"
  }
}

在macOS或Linux上,目录通常是~/.vscode/snippets/;在Windows上,则是%USERPROFILE%\AppData\Roaming\Code\User\snippets\。配置好后,在TypeScript文件中输入hdr并触发,就会插入类似下面的注释头:

/**
 * @file filename
 * @created 2024-6-15 14:28
 * @author Your Name
 */

// code here

最后记住这个本质:你插入的时间戳,是一个“历史快照”,而非一个“实时时钟”。即便你把编辑器开上一整天,每次触发片段插入的,仍然是触发那一刻的日期和时间,它不会自动跳动更新。理解这一点,就能避免很多后续的困惑。

来源:https://www.php.cn/faq/2333468.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

VSCode快捷键打开最近文件_快速切换历史工作记录
编程语言
VSCode快捷键打开最近文件_快速切换历史工作记录

角色与核心任务 你是一位顶级的文章润色专家,擅长将AI生成的文本转化为具有个人风格的专业文章。现在,请对用户提供的文章进行“人性化重写”。 你的核心目标是:在不改动原文任何事实信息、核心观点、逻辑结构、章节标题和所有图片的前提下,彻底改变原文的AI表达腔调,使其读起来像是一位资深人类专家的作品。 特

热心网友
05.03
VSCode自定义侧边栏图标_深度美化你的工作区布局
编程语言
VSCode自定义侧边栏图标_深度美化你的工作区布局

VSCode自定义侧边栏图标:深度美化你的工作区布局 怎么让自定义侧边栏图标真正显示出来 想让VSCode侧边栏换上自己的图标?这里有个关键认知需要先建立:VSCode本身并不支持通过用户设置文件,直接给任意视图“贴”上一个新图标。所谓的自定义,其本质是在你的扩展package json文件中,为v

热心网友
05.03
VSCode多分支对比_使用Git插件直观查看合并冲突
编程语言
VSCode多分支对比_使用Git插件直观查看合并冲突

Git插件“Compare Branches”无反应?先初始化本地仓库并确保VSCode工作区根目录为仓库根目录 话说回来,不少开发者都遇到过这个情况:在VSCode里想用Git插件对比分支,结果点那个“Compare Branches”选项,它愣是没半点反应。这通常不是什么插件坏了,根源往往在于一

热心网友
05.03
VSCode快速生成Node核心模块提示_增强原生API补全
编程语言
VSCode快速生成Node核心模块提示_增强原生API补全

VSCode 对 Node js 核心模块补全失效的主因是项目配置或语言服务异常 先明确一个核心判断:VSCode 默认就能对 Node js 核心模块(如 fs、path、http)提供基础补全。如果遇到提示缺失、参数不显示或者跳转失效,问题几乎都出在项目配置或语言服务状态上,而不是因为你插件没装

热心网友
05.03
VSCode插件市场版本管理_安装扩展的预览版与稳定版
编程语言
VSCode插件市场版本管理_安装扩展的预览版与稳定版

VSCode扩展预览版安装与管理的完整指南 先说一个核心情况:VSCode默认的插件市场界面,只会给你展示稳定版扩展。那些带着“实验性”新功能的预览版(Beta或Alpha),其实就藏在后台,只是需要一点“特殊操作”才能调出来。这第一步,往往就把不少人给卡住了。 VSCode 怎么安装扩展的预览版(

热心网友
05.03

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

Composer如何配置自定义的类加载路径_在 autoload 的 files 字段定义【进阶】
编程语言
Composer如何配置自定义的类加载路径_在 autoload 的 files 字段定义【进阶】

Composer如何配置自定义的类加载路径_在 autoload 的 files 字段定义【进阶】 为什么加了 files 还是报 Call to undefined function 遇到这个问题,十有八九是源头就出了问题:入口文件压根没引入 vendor autoload php,或者引入的位置

热心网友
05.03
怎么用VSCode开发Electron程序-主进程与调试工具关联方法
编程语言
怎么用VSCode开发Electron程序-主进程与调试工具关联方法

VSCode 调试 Electron 主进程:告别“断点失效”,回归 Node js 本质 调试 Electron 主进程,核心思路其实很简单:把它当作一个特殊的 Node js 进程来对待。 关键在于,别再执着于 VSCode 里那个名为 “electron” 的调试类型,而是用 type: "n

热心网友
05.03
git回退到指定版本的操作步骤【详解】
编程语言
git回退到指定版本的操作步骤【详解】

git回退到指定版本的操作步骤【详解】 开门见山,先说结论:想把代码回退到某个特定版本,git reset --hard 无疑是速度最快、效果最彻底的方法。但请注意,这个“大招”有明确的适用范围:仅限于你的改动还没推送到远程仓库,或者你拥有强制覆盖远程分支的权限。一旦代码已经合入了团队共享的主干分支

热心网友
05.03
Atom编辑器有哪些必装插件_Atom编辑器常用插件推荐教程【经典】
编程语言
Atom编辑器有哪些必装插件_Atom编辑器常用插件推荐教程【经典】

Atom已停止维护,apm官方源失效,需改用社区镜像源(如https: apm atom io cn)或手动下载GitHub包安装;仍可用插件需满足不联网、不调API、无后端依赖等条件。 Atom编辑器在2022年底就正式告别了官方维护,这已经是公开的事实。但话说回来,它并没有从我们的硬盘里消失。

热心网友
05.03
Composer如何配置脚本仅在特定条件执行_Composer脚本特定条件执行配置大全
编程语言
Composer如何配置脚本仅在特定条件执行_Composer脚本特定条件执行配置大全

Composer脚本无法原生支持条件判断,因scripts字段仅将字符串交由系统shell执行,而CI中环境变量未导出、Windows语法不兼容、autoload未加载等问题导致if语句失败;应改用PHP回调函数显式检测环境变量并控制流程。 先说一个核心结论:Composer脚本本身不具备原生的条件

热心网友
05.03