VSCode is an open source code editor owned by Microsoft, which is popular among developers. By installing plug-ins, you can develop projects in different languages on it, which is the Swiss Army Knife of choice for many developers.

In particular, VSCode’s Code Snippets let you easily write templates that repeat Code patterns, such as loops and conditional statements. Snippet here means Snippet. If you’re always writing repetitive snippets of code related to projects at work, make sure you finish reading this article.

Built-in snippets in VS Code

VS Code has snippets built in for a few languages. For example, in a JavaScript file, type for to select the snippet to apply, press Enter to bring in the code template, and then TAB to select the variable names and manually change them to the ones you want to use.

Of course, for some languages or frameworks that VSCode doesn’t support, such as React and Vue, we can find some high-quality snippets in VSCode’s plug-in marketplace.

In general, VSCode’s built-in and third-party market snippets are sufficient for daily development, but the snippets we use are project-specific, and it’s up to us to write our own custom snippets.

Write your own VSCode Snippets

Here’s how to write a Snippets with an implementation of a real requirement THAT I came across.

My requirement is to generate the following code snippet when I type RFC (react fun-component) in the TSX file. There is a minor requirement that the function names should be converted to the big camel style.

import React, { FC } from 'react';

interface IProps {}

const LinkButton: FC<IProps> = (props) = > {
  return (
    <div>
      
    </div>
  );
};

export default LinkButton;
Copy the code

Third-party plug-ins there are snippets of the React function components, such as ES7 React/story/GraphQL/React – Native snippets. But there are a few problems:

  1. The code style is not consistent with the project. Such as double or single quotes, semicolons, etc., which is fine, we can use ESLint to modify the code style when the file is saved.
  2. The prefix to be identified is too lengthy. Because there are too many styles, the same effect will have many similar writing methods, inES7 React/Redux/GraphQL/React-Native snippets,tsrfce(ts-react-fun-component-export) means to declare a normal function component class and export it as the default of the module. whiletsrafc(ts-react-arraw-fun-component) represents declaring an arrow function component class and exporting it as a named component (not the default). There are a bunch of other prefixes that are easy to get wrong, and we usually only use one of them. If we use our own snippets, we can make the prefixes shorter, and the user custom priority is higher than the plug-in’s, so we can find your snippets faster.
  3. Not flexible enough. If you rename app.js to app.js, Git will not recognize it. To solve this problem, some projects may require component file names to be named with an underscore. However, the component functions in the code should maintain the recommended hump style. Third party plugins are stupid enough to just use the filename style and manually change it to a big hump style every time. I’m so tired of that that I have to write a snippet that can convert.

Let’s get started.

Create a configuration file

We can click on the Settings button in the lower left corner of the editor and select the User Snippets, the type of Snippets you want to create.

Here we can select the scope of snippets.

  • global. Global is applied to every project. VSCode creates configuration files in the global configuration path, which can be language – independent.code-snippetsSuffixes, or file namesSpecify the language, such asc.jsonIndicates that the template code in the configuration file takes effect only in THE C language.
  • project. Valid within the project only. A.vscode directory is created in the root directory with a suffix named.code-snippetsYou cannot create a language-specific file like globally.

Fields that

VSCode will create a default snippet file for us, using annotation-enabled JSON syntax. There will be an annotated example, so we can uncomment it and change it to work.

{
	// Place your global snippets here. Each snippet is defined under a snippet name and has a scope, prefix, body and 
	// description. Add comma separated ids of the languages where the snippet is applicable in the scope field. If scope 
	// is left empty or omitted, the snippet gets applied to all languages. The prefix is what is 
	// used to trigger the snippet and the body will be expanded and inserted. Possible variables are: 
	// $1, $2 for tab stops, $0 for the final cursor position, and ${1:label}, ${2:another} for placeholders. 
	// Placeholders with the same ids are connected.
	// Example:
	"Print to console": {
		"scope": "javascript,typescript"."prefix": "log"."body": [
			"console.log('$1');"."$2"]."description": "Log output to console"}}Copy the code

First, through this simple example given by the official, briefly explain the meaning of various fields.

  • The outermost key (“Print to console”) represents the name of the snippet and acts as an identifier.
  • Scope specifies the language of the application. If there are multiple languages, separate them with commas. If you want to support all languages, simply omit this field.
  • Prefix is the input that triggers the intelligent prompt, and you can see that when the prefix log of the same name appears, the user-defined snippet comes ahead.
  • The body is the template code content, which is an array of strings, each string representing one line of code. Supports TAB key to switch cursor position (0,0, 0,1, etc.) and insert variable writing (for example, $TM_FILENAME_BASE represents the current file name with suffix removed).
  • Description: A detailed description of the snippet. Inside the body is our code snippet, where each string represents a line. The first few lines are simple, importing packages that declare the types of parameters passed by the component. In the fifth line, a more complex structure emerges.

implementation

Here we directly present the final code snippet that needs to be implemented.

{
	// Place your global snippets here. Each snippet is defined under a snippet name and has a scope, prefix, body and 
	// description. Add comma separated ids of the languages where the snippet is applicable in the scope field. If scope 
	// is left empty or omitted, the snippet gets applied to all languages. The prefix is what is 
	// used to trigger the snippet and the body will be expanded and inserted. Possible variables are: 
	// $1, $2 for tab stops, $0 for the final cursor position, and ${1:label}, ${2:another} for placeholders. 
	// Placeholders with the same ids are connected.
	// Example:
	"Custom React functional component": {
		"prefix": "rfc"."scope": "typescriptreact"."body": [
			"import React, { FC } from 'react';".""."interface IProps {}".""."const ${TM_FILENAME_BASE/(.*)/${1:/pascalcase}/}: FC<IProps> = (props) => {"."\treturn ("."\t\t<div>"."\t\t\t$0"."\t\t</div>"."\t);"."};.""."export default ${TM_FILENAME_BASE/(.*)/${1:/pascalcase}/};"]."description": "React Functional Component"}}Copy the code

Inside the body is our code snippet, where each string represents a line. The first few lines are simple, importing packages that declare the types of parameters passed by the component. In the fifth line, a more complex structure emerges.

Variables and regular conversions to variables

Here comes the concept of a variable. Variables can be roughly divided into several categories:

  • File information variable: obtained from the context of the file we are in. For example, TM_SELECTED_TEXT represents the selected content.
  • Time variable. For example, CURRENT_YEAR represents the current time.
  • Random number. For example, RANDOM represents a string of RANDOM numbers in base 10 with length 6
  • Comment block. For example, LINE_COMMENT represents a line comment.

Below we to ${TM_FILENAME_BASE/(. *) / ${1: / pascalcase}} structure is analyzed. This is a regex for a particular variable in the form:

${variable/regular expression/replacement content}Copy the code
  • TM_FILENAME_BASEIs the filename of the file we are editing, excluding the suffix.
  • (. *). This is a regular expression that matches the entire variable string, and the capture group is specified with parentheses, so $1 represents the entire string.
  • ${1:/pascalcase}Application of $1pascalcaseMethod to convert it to a big hump style.

If you’re familiar with JavaScript, this is roughly equivalent to:

TM_FILENAME_BASE.replace(/ / (. *).(match, $1) = > {
	return pascalcase($1); // pascalcase methods are provided by VSCode
})
Copy the code

Let’s move on. \t stands for TAB character. The actual conversion depends on what you do to the editor, for example it could be 4 Spaces or real tabs.

$0 is the last place the cursor stops, officially called Tabstops. VSCode will position the cursor from $1 in the snippet by pressing TAB. When that’s all done, if $0 is set, the cursor will run to $0.

At this point, our requirements are complete and uncomplicated. Let’s look at the end result:

conclusion

VSCode snippets are a great way to solve the problem of how efficient it is to write the same project code over and over again. Hopefully this article will give you a quick introduction to writing simple snippets. For more complex requirements, check out VSCode’s official documentation for more details.

If you’re interested, try implementing the for snippet at the beginning of the article and discuss it in the comments section.

Welcome to my public account: front-end watermelon brother. Learn cutting-edge industry news, share in-depth technical know-how, and obtain high-quality learning resources at the first time