VS Code项目中共享自定义的代码片段方案
VS Code项目中共享自定义的代码片段方案
一.问题背景
- 项目中注释风格不统一,如何统一注释风格
- 一些第三方组件库名称太长,每次使用都需要找文档,然后复制粘贴
- 部分组件库有自己的Snippets插件
- 一些组件能记住名称,但太长了手敲全称有点费时间
- 某些组件还有不少常用的参数,有不有办法在敲出组件的时候,加上一些参数
二.解法
稍加总结就不难看出,这些问题都能通过一些代码片段去解决
问题又来了:如何在项目中共享自定义的代码片段?
编辑器以VS Code为例,引入自定义代码片段的方案有如下几种:
- 通过扩展市场,以插件的方式引入(比较推荐各UI 组件库做一个)
- 直接在VS Code中引入自定义代码片段(首选项 -> 用户片段)
- 全局
当前项目
目前最适合当前场景的方案2-2
三.如何在当前项目中创建自定义的代码片段?
- 在当前项目中创建
.vscode文件夹 - 在其中创建以
.code-snippets结尾的文件如:- a.code-snippets
- b.code-snippets
first.code-snippets
{
"Print to console": { // 代码片段名称
"scope": "javascript,typescript", // 生效的语言
// (在文件中敲入prefix即可生成body中的内容)
"prefix": "lg", // 片段缩写
"body": [ // string[] 片段的完整内容,每个string代表一行
"console.log('$1');",
"$2"
],
// 在文件中输入完prefix时候,弹出此内容
"description": "Log output to console"
}
}
保存后就可以在工作区生效
body中可以有一些自定义的特殊内容
占位符$
- $number:
$1,$2,$3- 可指定代码片段触发落入编辑器之后的光标位置,光标位置按照从小到大排序,通过
Tab切换 $0用于设置光标最终的位置
- 可指定代码片段触发落入编辑器之后的光标位置,光标位置按照从小到大排序,通过
- ${number|option1,option2|}:
${1|op1,op2|}- 设置占位内容的可选项
- ${number:value}:
${1:default}- 可选内容只有一个的情况
变量
使用 $name 或者 ${name:default} 可以插入变量的值。如果未设置变量,则会插入其默认值或空字符串。当变量未知(未定义其名称)时,会将插入的变量名称转换为占位符。
VS Code内置了许多变量这里就不赘述了,
四.总结
通过在VS Code中创建.vscode文件夹写入x.code-snippets配置文件即可实现自定义代码块的共享
局限
- 必须写在.vscode目录中
- 不支持文件夹分类,即在
.vscode目录生效深度只能为1 - 增加项目的文件大小
- 需要手动把别人的片段文件放在
.vscode目录中
五.未来
部分库(组件/方法/语言)等提供了Snippets插件,但还有一些库没有提供,想把自己的代码块共享给其它人,开发插件的学习成本较高
有没有一种办法能够:
- 直接引入它人的代码块
- 传播方便
- 引入方便
- 对项目结构没有影响
- 更新迭代方便
我的设想:
Snippets文件以npm包的形式发布到npm仓库,本地通过一个VS Code插件自动扫描node_modules中的代码片段文件,然后使其在编辑器中生效
接下来去调研看看是否有现成的这种插件,没有的话自己搞个23333
参考文章:
VS Code项目中共享自定义的代码片段方案的更多相关文章
- 项目中解决实际问题的代码片段-javascript方法,Vue方法(长期更新)
总结项目用到的一些处理方法,用来解决数据处理的一些实际问题,所有方法都可以放在一个公共工具方法里面,实现不限ES5,ES6还有些Vue处理的方法. 都是项目中来的,有代码跟图片展示,长期更新. 1.获 ...
- 在Xcode中使用自定义的代码片段提高效率
拖动代码的时候按住option键,很难拖,注意方法:< 引用于:http://www.2cto.com/kf/201409/336245.html
- VS Code项目中通过npm包的方式共享代码片段的方案实现
VS Code项目中通过npm包的方式共享代码片段的方案实现 上周在 "VS Code项目中共享自定义的代码片段方案" 的文章中提到过一个共享代码片段的方案,上周经过调研后并没有发 ...
- Vue2/3 项目中的 ESLint + Prettier 代码检测格式化风格指南
Vue2/3 项目中的 ESLint + Prettier 代码检测格式化风格指南 因为平时都是使用 VSCode ESLint + Prettier 检测格式化不规范代码,但是随着接手的项目越来越多 ...
- VS code自定义用户代码片段snippet
打开VS code,“文件-首选项-用户代码片段-选择新建全局代码片段文件 “ 属性介绍:prefix 就是你自定义的快捷键 body 就是你自定义的代码片段 description 就是这 ...
- VSCode添加用户代码片段,自定义用户代码片段
在使用VScode开发中经常会有一些重复使用的代码块,复制粘贴也很麻烦,这时可以在VScode中添加用户代码片段,输入简写即可快捷输入. VScode中添加用户自定义代码片段很简单. 1.在VScod ...
- 自定义sublime代码片段
sublime text 已经有一些他们内置的一些代码片段,但是有时候,这些并不能满足我们,这就需要我们自定义一些代码片段. 步骤如下: 1.打开sublime text 2.选择 tools -&g ...
- sublime自定义snippet代码片段
相信很多人喜欢sublime编辑工具有两个原因:第一sublime很轻巧方便:第二sublime提供很多自定义拓展功能,包括很简单且和很好用的代码片段功能snippet文件. 今天,在这里就介绍下su ...
- 在项目中增加自定义icon图标
以MUI框架为例,内容来自于MUI官网. mui如何增加自定义icon图标 mui框架遵循极简原则,在icon图标集上也是如此,mui仅集成了原生系统中最常用的图标:其次,mui中的图标并不是图片,而 ...
随机推荐
- 【github技巧2】下载包加速
打开代下网站:https://g.widora.cn 直接输入 https开头的github地址 或需下载包地址的链接 获取链接 下载压缩包 备注:压缩包格式为tar,需要解压
- Angular SPA基于Ocelot API网关与IdentityServer4的身份认证与授权(三)
在前面两篇文章中,我介绍了基于IdentityServer4的一个Identity Service的实现,并且实现了一个Weather API和基于Ocelot的API网关,然后实现了通过Ocelot ...
- MyBatis——Mapped Statements collection does not contain value for XXX
报错信息: Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql. ...
- Mac打不开inkscape怎么办
本经验题目提到的是一款矢量图片编辑软件,对于打开不开的软件,完全可以通过卸载软件后进行安装.这里就从安装以及卸载的过程说明一下这个软件的安装卸载过程. 方法/步骤 打开电脑任意一个浏览器图标,进入浏览 ...
- Python的自定义属性访问跟描述器以及ORM模型的简单介绍
一 . 自定义属性访问 1.__getattr__ 作用:当我们访问属性的时候,如果属性不存在(出现AttrError),该方法会被触发. 2.__getattribute__ 作用:访问属性的时候, ...
- [JavaWeb基础] 009.Struts2 上传文件
在web开发中,我们经常遇到要把文件上传下载的功能,这篇文章旨在指导大家完成文件上传功能 1.首先我们需要一个上传文件的页面. <!--在进行文件上传时,表单提交方式一定要是post的方式, 因 ...
- debug PHP程序(xdebug、IntelliJ IDEA)
之前写PHP程序的都是echo调试,今天感觉太麻烦了就想起研究一下IntelliJ IDEA如何调试PHP程序. 从网上查找了很多资料,大部分都提到在IDE里开启服务,一下就懵了,怎么启这么多服务呢. ...
- 04 . 前端之JQuery
JQuery简介 # 1. jQuery是一个轻量级的.兼容多浏览器的JavaScript库.# 2. jQuery使用户能够更方便地处理HTML Document.Events.实现动画效果.方便地 ...
- 网络编程-TCP长连接和短连接
TCP是一个面向连接的协议.无论哪一方向另一方发送数据之前,都必须先在双方之间建立一条连接.下面会介绍一个TCP连接是如何建立的以及通信结束后是如何终止的. 一.TCP连接的建立与终止 1.1 建立连 ...
- 学习scrapy框架爬小说
一.背景:近期学习python爬虫技术,感觉挺有趣.由于手动自制爬虫感觉效率低,了解到爬虫界有先进的工具可用,尝试学学scrapy爬虫框架的使用. 二.环境:centos7,python3.7,scr ...