One, foreword

VS Code is one of the most popular ides for front-end development right now.

Have you installed any of your favorite plug-ins when using VS Code?

While enjoying the silky experience brought by various plug-ins, have you ever considered writing one yourself?

Now let’s rub one in our hands.

Tip: I am writing this article because I have seen a lot of interesting plug-ins in the community recently, and I have done a simple understanding of their implementation to satisfy my curiosity. Do a share here, personal level is limited, if there is a mistake to ask the audience to give directions.

Second, the overview

2.1 Description of this article

What can you learn from reading this article?

  • How to build, run, debug, and test plug-ins
  • How to take advantage of VS Code’s rich plug-in APIS
  • Learn some code examples to get you started

2.2 What can plug-ins do?

Here are some examples of what the extension API can do:

  • Change the look and feel of VS Code with a color or file icon theme
  • Add custom components and views to the UI – Extension workbench
  • Creating a Webview to display custom Web Pages built using HTML/CSS/JS – Webview Guide
  • Support for a new programming language – Language Extension overview
  • Support for debugging specific runtime – Debugger extension Guide

3. Initialization

3.1 create

Install Yeoman and VS Code Extension Generator by entering the following command:

npm install -g yo generator-code
Copy the code

Then running the generator will allow the user to do some custom configuration. The diagram below:

Configuration includes:

  • What type of extension do you want to create? TypeScript / JavaScript

  • What is the name of your plugin?

  • What is your plugin’s identifier?

  • What is the description of your plugin?

  • Want to initialize a Git repository?

  • Which package manager to use? npm / yarn

Here I will follow the official example to demonstrate:

3.2 debugging

So once the project is created, how do you start debugging the plug-in?

Entering the command code./ HelloWorld in the terminal will open the folder in the editor.

Press F5 in the editor to open a new editor window for debugging the plug-in in development.

Enter the HelloWorld run command in the command panel of the new window (Ctrl + Shift + P). You will see HelloWorld from HelloWorld! The notice.

Iv. Life cycle

From the perspective of life cycle, it is divided into three parts:

  • Activation Event: Sets the timing for plug-in Activation. Located in package.json.
  • Contribution Point: Set where new features are added in VS Code, which features are enhanced by this plug-in. Located in package.json.
  • RegisterIn:extension.jsFor the function to writevscode.commands.register...Activation EventContribution PointOr set the listener. Located in the entry file (default isextension.js)activate()In a function.

package.json

The package contains the following properties related to plug-ins, where main is the relative path to the plug-in’s entry file.

// package.json
{
  "activationEvents": [
    "onCommand:vscode-demo.helloWorld"]."main": "./extension.js"."contributes": {
    "commands": [{"command": "vscode-demo.helloWorld"."title": "Hello World"}}}]Copy the code

4.1 the Activation Event

The initial Hello World is activated only after the vscode-demo.helloWorld command is executed. After we add onCommand: vscode-demo.hellovscode to the activationEvents property in package.json, we can activate the plug-in under the vscode-demo.hellovscode command. Do other things.

// package.json
{
  "activationEvents": [
    "onCommand:vscode-demo.helloWorld"."onCommand:vscode-demo.helloVscode"]}Copy the code

4.2 Contribution Point

Contributions indicate which projects are enhanced by the plug-in.

For example, we want to add a new vscode -demo.hellovscode directive:

// package.json
{
  "contributes": {
    "commands": [{"command": "vscode-demo.helloWorld"."title": "Hello World"
      },
      {
        "command": "vscode-demo.helloVscode"."title": "Hello VS Code"}}}]Copy the code

4.3 the Register

The full API is: registerCommand(command: string, callback: (args: any[]) => any, thisArg? : any): Disposable

The main function of this is to register a command for the callback code and subscribe to the corresponding command events via subscriptions.push().

For example, let’s improve something like Hello World.

// extension.js
function activate(context) {
  let disposable = vscode.commands.registerCommand(
    "vscode-demo.helloWorld".() = > {
      vscode.window.showInformationMessage("Hello World!"); }); context.subscriptions.push(disposable);// New subscription event
  let helloVscode = vscode.commands.registerCommand(
    "vscode-demo.helloVscode".() = > {
      vscode.window.showInformationMessage("Hello VS Code!"); }); context.subscriptions.push(helloVscode); }Copy the code

Five, the Webview

The Webview API allows extensions to create fully customizable views in VS Code. For example, the built-in Markdown extension uses Web views to render Markdown previews. In addition to what VS Code’s native API supports, webViews can also be used to build complex user interfaces.

You can think of the network view as internal to VS Code controlled by the IFrame extension. A Web view can render almost any HTML content in this framework, and it communicates with extensions using messaging. This freedom makes the WebView incredibly powerful and opens up a whole new set of extension possibilities.

Next, let’s try displaying the following everyday expression in a Webview.

Start by adding the new directive to package.json

// package.json
{
  "activationEvents": [..."onCommand:vscode-demo.openNewTab"]."main": "./extension.js"."contributes": {
    "commands": [{..."command": "vscode-demo.openNewTab"."title": "Start new Webview"."category": "Open New Tab"}]}}Copy the code

Then let’s adjust extension.js

// extension.js
const vscode = require("vscode");

function activate(context) {... context.subscriptions.push( vscode.commands.registerCommand("vscode-demo.openNewTab".() = > {
      // Create and show a new webview
      const panel = vscode.window.createWebviewPanel(
        "startCoding".// Identifies the type of the webview. Used internally
        "Start work, start mixed base.".// Title of the panel displayed to the user
        vscode.ViewColumn.One, // Editor column to show the new webview panel in.
        {} // Webview options. More on these later.); panel.webview.html = getWebviewContent(); })); }exports.activate = activate;

function deactivate() {}

function getWebviewContent() {
  return ` 
         
       < span style = "box-sizing: border-box;      `;
}

module.exports = {
  activate,
  deactivate,
};
Copy the code

Ok, let’s try it again.

The diagram below:

GIF of mixed base salary is displayed, interested students can play.

There are a lot of advanced features to be explored.

Six, thank

  • If this article helped you, just give it a like! Thanks for reading.