初识 vscode 插件开发

what-is-vscode.png

之前一直觉得插件开发很难,迟迟不敢接触,但每次看到或者用别人开发的插件时,又非常羡慕,这次刚好有个项目开需要开发 vscode 插件,借此机会终于要对 vscode 插件下手了。本篇文章主要包含入门开发和过程中遇到的一些问题,希望能给大家带来帮助,避免跟我一样踩坑。下面就具体的来看一下吧:

安装脚手架

使用官方脚手架生成项目,要先安装脚手架,命令如下:

npm install -g yo generator-code

生成项目

切到对应目录,执行 yo code,将会出现如下图的一个选择,根据自己的需求选择对应类型的扩展模板,剩下的就根据提示一步步操作即可,运行完后就生成了一个 vscode 插件项目。

image-20210402094946242
image

项目核心结构

 执行 yo code 生成项目后,仔细看下项目结构,我们比较重要的其实就两个文件,分别是 package.json 和 extension.js。package.json 是整个插件工程的配置文件,extension.js 是工程的入口文件,下面我们详细介绍一下这两个文件。

pacgage.json

下面是 package.json 文件的常用配置:

{
  // 插件名称,需用全小写无空格的字母组成
  "name": "vue-typescript-snippets-plugin",
  // 插件市场显示的插件名称
  "displayName": "vue-typescript-snippets-plugin",
  // 简单描述插件的功能
  "description": "生成 ts 的 vue 代码片段",
  "version": "0.0.1",
  // 插件支持的 vscode 最低版本
  "engines": {
     "vscode": "^1.55.0"
  },
  // 插件的应用市场分类,可选值包括 [Programming Languages, Snippets, Linters, Themes, Debuggers,Formatters, Keymaps, SCM Providers, Other, Extension Packs, Language Packs]
  "categories": [
     "Other"
  ],
  // 扩展的激活事件数组
  "activationEvents": [
     "onCommand:vue-typescript-snippets-plugin.helloWorld"
  ],
  // 插件入口
  "main": "./dist/extension.js",
  // 配置内容项
  "contributes": {
      // 命令
      "commands": [
    {
      "command": "vue-typescript-snippets-plugin.helloWorld",
      "title": "Hello World"
    }
      ]
  },
  "scripts": {
      "vscode:prepublish": "yarn run package",
      "compile": "webpack",
      "watch": "webpack --watch",
      "package": "webpack --mode production --devtool hidden-source-map",
      "test-compile": "tsc -p ./",
      "test-watch": "tsc -watch -p ./",
      "pretest": "yarn run test-compile && yarn run lint",
      "lint": "eslint src --ext ts",
      "test": "node ./out/test/runTest.js"
  },
  "devDependencies": {
      "@types/vscode": "^1.55.0",
      "@types/glob": "^7.1.3",
      "@types/mocha": "^8.0.4",
      "@types/node": "^12.11.7",
      "eslint": "^7.19.0",
      "@typescript-eslint/eslint-plugin": "^4.14.1",
      "@typescript-eslint/parser": "^4.14.1",
      "glob": "^7.1.6",
      "mocha": "^8.2.1",
      "typescript": "^4.1.3",
      "vscode-test": "^1.5.0",
      "ts-loader": "^8.0.14",
      "webpack": "^5.19.0",
      "webpack-cli": "^4.4.0"
  }
}

这个就是我们初始化生成的 package.json 文件,其中比较核心的是 activationEventscontributes

activationEvents

activationEvents 是配置激活事件的,我们插件一开始是没有被激活的,只有当触发了 activationEvents 中配置的事件,插件才会被激活,激活的事件列表如下:

  • onLanguage: 打开指定语言文件时会激活

    "activationEvents": [
         "onLanguage:html"
     ]
    
  • onCommand: 调用命令时会激活

    "activationEvents": [
      "onCommand:extension.sayHello"
    ]
    
  • onDebug: 调试会话启动前会激活

    "activationEvents": [
      "onDebug"
    ]
    
  • workspaceContains: 工作区有包含符合 glob模式的文件时会激活

    "activationEvents": [
      "workspaceContains:**/.editorconfig"
    ]
    
  • onFileSystem: 以协议打开文件或文件夹时会激活

    "activationEvents": [
      "onFileSystem:sftp"
    ]
    
  • onView: 指定 id 的视图展开时会激活

    "activationEvents": [
      "onView:nodeDependencies"
    ]
    
  • onUri: 插件的系统级 URI 打开时会激活,这个URI 协议需要带上vscode或者vscode-insiders协议。

    "activationEvents" [
      "onUri"
    ]
    
  • onWebviewPannel: 当 vscode 需要恢复一个符合 viewType 的 webview 时会激活。

    "activationEvents": [
      "onWebviewPanel:catCoding"
    ]
    
  • onCustomEditor: 当 vscode 需要创建一个符合 viewType 的自定义编辑器时会激活。

    "activationEvents": [
      "onCustomEditor:catCustoms.pawDraw"
    ]
    
  • onStartupFinished: 在 vscode 启动后一段时间会激活,类似于”*“, 但是不会减慢 vscode 的启动速度。

    "activationEvents": [
      "onStartupFinished"
    ]
    
  • *: vscode启动时会激活,为确保用户体验,请在没有其他激活事件时使用。

    "activationEvents": [
      "*"
    ]
    

contributes

还有一个比较核心的配置是contributes,它被称为 Contribution Points,可以用来注册各种配置项来扩展 vscode 的能力。下面是目前可用的配置项列表:

configuration:配置的内容会暴露给用户,可以从”用户设置“和”工作区设置“中修改你暴露的选项。

configurationDefaults:为特定语言配置编辑器的默认值。

commands:设置命令标题和命令体,会展示在命令面板(⇧⌘P)。

menus:为编辑器或文件管理器设置命令的菜单项。至少包含菜单显示的时机和选择菜单执行的命令。

keybindings:配置快捷键

languages:配置语言,引入新的语言或加强 vscode 已有的语言支持。

debuggers:配置 vscode 调试器。

breakpoints:配置哪些语言可以设置断点。

grammars:为一门语言配置 TextMate 语法

themes:为 vscode 增加主题

iconThemes:配置 vscode 的文件图标主题

productIconThemes:配置 vscode 的产品图标主题

snippets:为一门语言增加代码片段

jsonValidation:配置 json 文件的校验器

views:为 vscode 增加视图

viewsWelcome:配置自定义视图的欢迎内容

viewsContainers:配置自定义视图的视图容器

problemMatchers:配置问题定位器的模式

problemPatterns:配置可以在问题定位器(见上)中可以使用的模式名称

taskDefinitions:配置和定义一个 object 结构,定义系统中唯一的配置任务

colors:配置可用于编辑器装饰器和状态栏的颜色

typescriptServerPlugins:配置 vscode 的 js 和 ts 支持的 Typescript 服务器插件

resourceLabelFormatters: 配置资源标签格式化程序,它将指定如何在工作台中的任何地方显示 URI

extension.js

  
extension.js 是插件的入口文件,会导出两个函数:activate 和的activate,当注册的激活事件被触发时,即会执行 activate 中的代码,deactivate 则提供了插件关闭前执行清理工作的机会。由于这里的代码只会被执行一次,所以需要在 activate 中使用 registerCommand 来注册命令,这里的参数必须与 package.json 中定义的 一致,下面是简单的示例:

image-20210402174828752

  
registerCommand的第二个参数匿名函数中的代码,在每次该命令被触发时都会执行一次。我们在vscode 中启动调试之后,会看到弹出一个新的窗口,在新窗口按下 command+shift+p 即可调用插件,输入我们定义的 Hello world 会触发上面匿名函数内的代码,启动我们的插件,在 vscode 的右下角出现一个通知框,这就表示我们的插件启动成功了,接下来我们就可以根据需求开发自己想要的功能了。

运行调试

我们在插件开发过程中,如何实时看到自己插件的效果呢,vscode 提供给我们了,按下图中的顺序操作,1 将切到 debug 的操作面板,点击 2 会开启一个新的窗口,同时出现 3 这样一个操作 bar,可以停止和刷新已经在运行中的插件。还可以直接在对应的代码前加断点,执行命令触发断点后开始调试,也可以通过 console.log() 将日志打印在控制台,但是过于复杂的对象就不能显示了。

image-20210415135934408
image-20210415143508117

打包发布

  • 安装 vsce(Visual Studio Code Extension)

    npm i vsce -g
    
  • 打包成 vsix 文件:

    vsce package
    

    tips:生成的 vsix 文件不能直接拖入安装,只能从扩展的右上角选择 Install from VSIX 安装。

  • 发布到应用市场

    注册登陆网站:登陆网站 https://dev.azure.com/vscode 获取一个 access token,用这个 token 来创建一个 publisher。

    创建发布者账号: vsce create-publisher (publisher name)

    登陆账号: vsce login (publisher name)

  • 发布

    vsce publish
    

    增量发布:版本号(major.minor.patch)

    vsce publish patch(minor/major)
    

    取消发布:

    vsce unpublish (publisher name).(extension name)
    
  • 更新

    修改版本号,重新执行 vsce publish 即可

问题及解决方案

  1. 生成的 demo 运行后,触发 sayHello 的命令报错:
    image-20210330094850353

    原因是:vscode 版本低于插件要求的最低版本,即在 package.json 中定义的 engines 属性。

  2. 写snippets时,测试发现并不生效,跟官方文档对比后,发现少写了一个属性 scope,之前看的教程比较老,没有这个属性也可以,但是看最新文档写的是四个属性都为必填值时才能生效。

    image-20210330173246357

参考资料

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

推荐阅读更多精彩内容

  • 夜莺2517阅读 127,709评论 1 9
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,520评论 28 53
  • 兔子虽然是枚小硕 但学校的硕士四人寝不够 就被分到了博士楼里 两人一间 在学校的最西边 靠山 兔子的室友身体不好 ...
    待业的兔子阅读 2,583评论 2 9
  • 信任包括信任自己和信任他人 很多时候,很多事情,失败、遗憾、错过,源于不自信,不信任他人 觉得自己做不成,别人做不...
    吴氵晃阅读 6,178评论 4 8