VsCode如何创建自定义用户片段

自定义代码片段

把重复利用的代码模板定义成自己的代码片段,提高编码效率和减少不必要的错误产生

  1. 设置

打开VS code,“文件-首选项-用户代码片段”(file-preference-User Snippets)
在下拉列表中选择html文件,此时在VS code的应用数据文件夹内自动新建了一个名为html.json的文件,我们在这个json文件中定义我们的代码片段
我们需要首先定义snippet name,在snippet name中,prefix和body是必不可少的两个字段(The prefix is what is used to trigger the snippet and the body will be expanded and inserted.)

我们定义一个html框架,命名为 demohtml

"demohtml": {
	"scope": "html",
    "prefix": "demohtml",
    "body": [
        "<!DOCTYPE html>",
        "<html lang=\"en\">",
        "<head>",
        "\t<meta charset=\"UTF-8\">",
        "\t<title>${1:Title}</title>${2}",
        "</head>",
        "<body>",
        "\t${3}",
    "</body>",
    "</html>",
    "${0}"
    ],
    "description": "create a html frame"
}
{
	// Place your 全局 snippets here. Each snippet is defined under a snippet name and has a scope, prefix, body and 
	// description. Add comma separated ids of the languages where the snippet is applicable in the scope field. If scope 
	// is left empty or omitted, the snippet gets applied to all languages. The prefix is what is 
	// used to trigger the snippet and the body will be expanded and inserted. Possible variables are: 
	// $1, $2 for tab stops, $0 for the final cursor position, and ${1:label}, ${2:another} for placeholders. 
	// Placeholders with the same ids are connected.
	// Example:
	"Print to console": {
		"scope": "html",
		"prefix": "demohtml",
		"body": [
        "<!DOCTYPE html>",
        "<html lang=\"en\">",
        "<head>",
        "\t<meta charset=\"UTF-8\">",
        "\t<title>${1:Title}</title>${2}",
        "</head>",
        "<body>",
        "\t${3}",
		"</body>",
		"</html>",
		"${0}"
		],
		"description": "自定义的html"
	}
}
//svg代码片段
{
	"Print to console": {
		"scope": "html",
		"prefix": "svg",
		"body": [
			"<svg width=\"400\" height=\"400\" xmlns=\"http://www.w3.org/2000/svg\">",
			"\t${3}",
     		"</svg>"
		],
		"description": "svg基础片段"
	}
}

保存,新建一个html文件,输入demohtml,按下Tab键,就可以自动补齐整个框架
在这里插入图片描述

语法:

在body中,使用转义字符\来书写制表符Tab、双引号"等内容;
使用${num: default name}来定义输入位置,按下Tab键来递进光标到下一个;
num的值为0,1,2,3…。0为光标的最终位置,1,2,3…决定了光标的顺序位置;
default name是默认值,可按下Tab不编辑直接跳过。

全局和特定代码片段

代码片段分为两种:全局和特定,这意味着我们可以定义适用于多种文件类型的代码片段,也可以定义仅仅针对于一种文件类型的代码片段。

全局代码片段的文件后缀名为.code-snippets,在用户代码片段下拉列表中,最上方有一个“新建全局代码片段文件”。

全局代码片段的语法规则和特定代码片段的语法规则一致,唯一区别在于其增加了一个字段scope,用于指定该规则适用于何种语言:

{
    "For_Loop": {
        "prefix": "for",
        "scope": "javascript,typescript",
        "body": [
          "for (const ${2:element} of ${1:array}) {",
          "\t$0",
          "}"
        ],
        "description": "For Loop"
    },
}

自定义引用css和JavaScript的标签的代码片段

"link template": {
    "prefix": "<link rel...",
    "body": [
        "<link rel=\"stylesheet\" type=\"${1:text/css}\" href=\"${2}\">${0}"
    ],
    "description": "complete css link"
},
"script template": {
    "prefix": "<script type...",
    "body": [
        "<script type=\"${1:text/javascript}\" src=\"${2}\"></script>${0}"
    ],
    "description": "complete script quote"
}
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在VSCode自定义Vue的代码片段,你可以按照以下步骤进行操作: 1. 在VSCode的顶部菜单栏中找到【文件】-【首选项】-【用户片段】,点击进入用户片段设置页面。 2. 在打开的输入框中,输入文件类型为"vue"的代码片段生效的语言类型,即输入"vue"并选择提示的"vue.json"文件。 3. 在打开的"vue.json"文件中,你可以使用代码块的方式来定义你的代码片段。 - 全局作用域的代码块:这些代码块对所有文件都有效,不限制文件类型。你可以在文件中敲出触发代码块的关键字,然后按Tab键来插入代码块。 - 文件夹作用域的代码块:这些代码块只在指定文件夹下的文件中有效。你可以将代码块文件创建在指定文件夹的.vscode文件夹下,然后在文件中敲出触发代码块的关键字来插入代码块。 - 指定文件类型的代码块:这些代码块只在指定文件类型中有效。你可以在代码块文件中指定文件类型,并在相应的文件中敲出触发代码块的关键字来插入代码块。 4. 编辑和删除代码块:你可以在对应的代码块文件中对代码块进行编辑和删除,以满足你的需求。 需要注意的是,VSCode自定义代码片段的类型分为全局作用域、文件夹作用域和特定文件类型作用域。 - 全局作用域的代码块创建VSCode软件内部的文件,不会随着项目的关闭而失效,会一直存在。 - 文件夹作用域的代码块创建在某个文件下的.vscode隐藏文件夹中,只适用于当前文件夹,离开这个文件夹就无法使用该代码块。 - 特定文件类型作用域的代码块也是创建VSCode中的,但只适用于你指定的文件类型。 希望以上信息对你有帮助,如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JackieDYH

谢谢您嘞!我会继续加油地

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值