博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
VS code自定义用户代码片段snippet
阅读量:5169 次
发布时间:2019-06-13

本文共 1771 字,大约阅读时间需要 5 分钟。

参考资料:

1. 为什么要自定义代码片段?

 在使用Dreamweaver、Webstorm等HTML页面编辑器时,其自带的自动补全功能(我更乐意称之为模板)往往可以减少我们写代码时的工作量,但IDE打开速度慢、占用内存高的缺点不断蚕食我的耐心。当发现VS code的代码片段自定义功能后,我决定将web开发的主战场转移至其上,其轻量级和可扩展性是前所未有的吸引人的。

2. 怎么做?

 由于是在书写html页面时用到了代码片段功能,因此以创建html文件的代码片段为例说明创建的流程、语法。

2.1 流程

 打开VS code,“文件-首选项-用户代码片段”(file-preference-User Snippets),在下拉列表中选择html文件,此时在VS code的应用数据文件夹内自动新建了一个名为html.json的文件,我们在这个json文件中定义我们的代码片段。

 我们需要首先定义snippet name,在snippet name中,prefixbody是必不可少的两个字段(The prefix is what is used to trigger the snippet and the body will be expanded and inserted.)

 我们定义一个html框架,命名为html template,代码如下:

"html template": {    "prefix": "html template",    "body": [        "",        "",        "",        "\t
", "\t${1:Title}${2}", "", "", "\t${3}", "", "", "${0}" ], "description": "create a html frame"}

 保存,新建一个html文件,输入html template,按下Tab键,就可以自动补齐整个框架。

2.2 语法说明

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

2.3 Global or Specific Snippets

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

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

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

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

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

"link template": {    "prefix": "
${0}" ], "description": "complete css link"},"script template": { "prefix": "${0}" ], "description": "complete script quote"}

转载于:https://www.cnblogs.com/whuls/p/9356520.html

你可能感兴趣的文章
深度学习之前馈神经网络(前向传播和误差反向传播)
查看>>
IEnumerable<T>和IQueryable<T>区别
查看>>
(转)MFC界面风格
查看>>
Centos7 tmux1.6 安装
查看>>
二叉树(三)
查看>>
linux加密文件系统 fsck 无法修复一例
查看>>
【linux配置】VMware安装Redhat6.5
查看>>
AI自主决策——有限状态机
查看>>
Python装饰器学习笔记
查看>>
iframe父子窗口取值
查看>>
利用Python进行数据分析_Pandas_数据结构
查看>>
2018-2019 2 20175230《Java程序设计》第九周学习总结
查看>>
python3中sum
查看>>
spring声明式事务管理
查看>>
JavaScript高阶函数(Heigher-order function)
查看>>
《计算机组成原理》第6章:总线
查看>>
Nginx的反向代理的配置
查看>>
JAVA之单例模式
查看>>
关于String str =new String("abc")和 String str = "abc"的比较
查看>>
Android软件架构及子系统介绍
查看>>