VSCode 插件开发(二):插件开发实践

前言

来啦老铁!

在上一篇文章:VSCode 插件开发(一):Hello World
中,我们一起学习了 VSCode 插件项目是如何创建、VSCode 插件的基础知识等,而今天我们将基于上一篇文章,继续来尝试开发一个稍微复杂点的插件。

实际上,关于插件开发,VSCode 有较为完善的文档,请参考:VSCode 插件开发文档

学习路径

  1. 插件功能设计;
  2. 编写插件代码;
  3. 为插件设置快捷键;
  4. 为插件设置菜单项;

1. 插件功能设计;

我学习 VSCode 插件开发的初衷是:

  • 想要通过这个插件与公司内部用例管理平台集成,从而能帮助我在一定程度上自动生成自动化代码“框架”;

在这一点上,我之前是用保存好的代码片段来完成的,代码片段虽好,可无法做一些逻辑处理,如请求一个接口后,将接口内容填入代码片段,然后再填充代码;

同时能想到的其他想法是,通过插件,我可以:

  • 简单快速地得到用例是否已发生变化,与前一个版本或前面几个版本的差异在哪;
  • 对用例管理平台上的用例进行字段更新;
  • 也许还可以触发 Jenkins job 等操作;
  • 等。

这里面涉及到公司内部平台,不适合拿来写文章,我们用一个类似的例子来演示,即:

  • 在我们的 VSCode 插件中调用免费的公共接口(模拟调用公司用例管理平台的接口),在拿到接口返回后,对返回内容进行读取,拼凑出我们的代码片段(模拟拼出我们的自动化代码“框架”),最后填充到文件中去;

2. 编写插件代码;

  1. 首先安装用于发请求的模块 axios:
npm install axios --save-dev
  1. 先实现简单的向文件中写入固定字符串的逻辑;
  • 代码如下:
// The module 'vscode' contains the VS Code extensibility API
// Import the module and reference it with the alias vscode in your code below
import * as vscode from 'vscode';

// this method is called when your extension is activated
// your extension is activated the very first time the command is executed
export function activate(context: vscode.ExtensionContext) {

    // Use the console to output diagnostic information (console.log) and errors (console.error)
    // This line of code will only be executed once when your extension is activated
    console.log('Congratulations, your extension "case2script" is now active!');

    // The command has been defined in the package.json file
    // Now provide the implementation of the command with registerCommand
    // The commandId parameter must match the command field in package.json
    let disposable = vscode.commands.registerCommand('case2script.helloWorld', () => {
        // The code you place here will be executed every time your command is executed
        // Display a message box to the user
        vscode.window.showInformationMessage('Hello World from case2script! I am Dylan Zhang ~');

        let editor = vscode.window.activeTextEditor;
        if (!editor) {
            return;
        }
        let snippet: vscode.SnippetString = new vscode.SnippetString("this is snippet test~");
        editor.insertSnippet(snippet);
    });

    context.subscriptions.push(disposable);
}

// this method is called when your extension is deactivated
export function deactivate() { }

  • 运行插件后,在任意的文件内,使用命令 Command + Shift + P(windows 为:Ctrl + Shift + P),选取使用我们的插件:
使用插件
  • 就能快速看到效果啦(自动输入一行字符:this is snippet test~):
效果
  1. 然后再实现向文件中写入经过处理后的字符串(调 API,取 API 返回,然后经过处理后的字符串)的逻辑;

这里,我们要做的是将上述代码中的 "this is snippet test~" 替换为调完 API,取 API 返回,然后经过处理后的字符串,即为动态的字符串;

免费公开接口
  • 我们计划取 name 对应的值和 introduction 对应的值,作为文本填入我们的目标文件;

  • 代码如下:

// The module 'vscode' contains the VS Code extensibility API
// Import the module and reference it with the alias vscode in your code below
import * as vscode from 'vscode';
import axios from 'axios';

// this method is called when your extension is activated
// your extension is activated the very first time the command is executed
export async function activate(context: vscode.ExtensionContext) {

    // Use the console to output diagnostic information (console.log) and errors (console.error)
    // This line of code will only be executed once when your extension is activated
    console.log('Congratulations, your extension "case2script" is now active!');

    // The command has been defined in the package.json file
    // Now provide the implementation of the command with registerCommand
    // The commandId parameter must match the command field in package.json
    let disposable = vscode.commands.registerCommand('case2script.helloWorld', async () => {
        // The code you place here will be executed every time your command is executed
        // Display a message box to the user
        vscode.window.showInformationMessage('Hello World from case2script! I am Dylan Zhang ~');

        let editor = vscode.window.activeTextEditor;
        if (!editor) {
            return;
        }

        let res = await axios.get("https://www.zhihu.com/api/v4/topics/19552112");
        let snippetString = "name: " + res.data.name + "\n" + "introduction:" + res.data.introduction;

        let snippet: vscode.SnippetString = new vscode.SnippetString(snippetString);
        editor.insertSnippet(snippet);
    });

    context.subscriptions.push(disposable);
}

// this method is called when your extension is deactivated
export function deactivate() { }

  • 同理,插件运行后效果如下:
插入动态文本

3. 为插件设置快捷键;

快捷键的设置非常简单,只需要在插件项目内的 package.json 找到 contributes 字段,按我们的需要写好快捷键配置,比如我们希望在文件内,键盘按下 Command+M(windows 上为 Ctrl+M)组合键时,完成插件的调用。

快捷键配置如下:

快捷键配置

其中:

  • "command": "case2script.helloWorld" 与 commands 中我们注册的命令 command 一致;
  • "key": "ctrl+m" 为 windows 机器对应的快捷键;
  • "mac": "cmd+m" 为 mac 机器对应的快捷键;
  • "when": "editorFocus" 为什么时候可以调用快捷键从而可以调用插件;

when 的其他选项参考:when 的其他选项参考

执行效果与未使用快捷键一致,方便多了:

快捷键执行

4. 为插件设置菜单项;

与快捷键设置类似,设置菜单项也是在 package.json 内的 contributes 字段下进行配置;

菜单项配置如下:

菜单项配置

其中:

  • "when": "editorFocus" 为什么时候可以展示菜单从而可以选择我们的菜单项进行调用插件;
  • "command": "case2script.helloWorld" 与 commands 中我们注册的命令 command 一致;
  • "alt": "case2script.helloWorld" 此处定义了备用命令,即按住alt键打开菜单时将执行对应命令,笔者的电脑为 mac 电脑,无法验证效果,见谅~
  • "group": "navigation" 控制菜单的分组和排序,不同类型的菜单拥有不同的默认分组,其中,editor/context 中有这些

group 默认分组:

a. navigation: 放在这个组的永远排在最前面;
b. 1_modification - 更改组;
c. 9_cutcopypaste - 编辑组;
d. z_commands - 最后一个默认组,其中包含用于打开命令选项板的条目。

分组

于是,我们就能用鼠标右键找到我们的菜单项并调用插件啦,菜单项也能让我们更方便使用插件~

菜单项

至此,我们学习了开发稍微复杂的 VSCode 插件的过程、插件快捷键、菜单项的设置等常用功能点,更多知识点还有待后续探索与实践~

可以预见,拥有上述插件知识,开发其他类似功能的插件,必定不在话下(我的初衷应该问题不大)!!!

下一篇,我们可能会一起来学习如何本地安装 VSCode 插件、发布 VSCode 插件到插件市场等,可期~

能力有限,欢迎指正、互相交流,感谢~

如果本文对您有帮助,麻烦点赞、关注!

感谢~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容

  • 1.概览 1.1 vscode插件可以做什么 vscode编辑器是可高度自定义的,我们使用vscode插件几乎可以...
    雪山飞狐_91ae阅读 52,234评论 4 40
  • 前言 笔者正在学习开发一款VSCode插件,文章为学习所做的笔记,供学习使用。 1. 命令的写法 在 extens...
    JaniceZD阅读 1,132评论 0 0
  • 之前一直觉得插件开发很难,迟迟不敢接触,但每次看到或者用别人开发的插件时,又非常羡慕,这次刚好有个项目开需要开发 ...
    vermouth_Fee阅读 630评论 0 0
  • 扩展Sketch 入门插件基础您的第一个插件开发环境调试ActionAPI发布插件 高级插件捆绑插件,脚本和命令插...
    iOSDevLog阅读 17,443评论 0 34
  • 最近公司要使用vscode作为开发工具,需要对vscode做一些定制功能,比如snippet提示,内容提示,以及其...
    rill_阅读 20,947评论 12 18