插件界的瑞士军刀,vs code已经无所不能!

powertools可以称得上插件界的瑞士军刀

相对于VS Code中大多数插件的出现为了解决某一项弊端和不足,powertools则聚合了很多强大且实用的功能,能够增强VS Code的功能,并提升VS Code的使用体验。

powertools就如同之前使用iOS系统时使用过的一款软件Workflow,它相对于大多数插件功能更加丰富,但是门槛也更高一些。

也就是说,想要最大发挥这款插件的价值,仅凭默认的配置是不行的,还需要结合脚本使用。换句话说,需要自己会用js开发一些脚本,如同开发一款简易版的vs code插件,来实现对应的功能。

下面,就来看介绍一下这款插件的基本使用和优点吧!

安装

我相信,对于使用过VS Code的同学来说,安装插件是一件再容易不过的事情。

安装插件的方法主要有两种:

方法1:手动安装

点击左侧的活动栏上的扩展图标,然后搜索powertools,点击安装即可。

方法2:命令安装

使用快捷键Ctrl+P,输入命令ext install vscode-powertools,点击Enter键就可以安装插件。

如果上述两种方式走不通,也可以访问访问网页端插件市场[1],搜索对应的插件安装即可。

powertools

既然能够被称为瑞士军刀,那么它的功能自然就会非常丰富。

这款插件的功能大体可以分为如下几类:

  • 应用

  • 按钮

  • 命令

  • 事件

  • 工具

下面就分别来介绍一下。

应用

这里所说的应用是基于Node.js的脚本,可通过Web视图运行,并且还可以与Visual Studio Code实例进行交互。

创建应用只需要如下3步:

  1. 点击按键F1或者Ctrl+Shift+P

  2. 选择Power Tools: Apps

  3. 选择Create App ...

输入对应应用的名称就完成了一款应用的创建,然后再执行前面的1~2步,第3步选择Open App ...就可以打开初始化的应用。

img

这对于很多使用Vue开发前端的同学能够提供很大便利。

按钮

在开发过程中,会有很多重复性的动作,例如,执行某个Python脚本、运行某个shell脚本。我们没有必要再去打开终端进入对应的工程目录,执行对应的任务或者shell脚本,通过添加1个vs code快捷按钮就可以实现一项繁琐且频繁用到的功能。

使用按钮功能,需要配置一下vs code的配置文件settings.json,

{
  "ego.power-tools": {
  "buttons": [
  {
  "text": "Click me!",
  "tooltip": "You run an awesome script by clicking that button!",
  "action": {
  "type": "script",
  "script": "my_button.js"
  }
  }
  ]
  }
 }

在上述配置中可以看出,这个按钮名称为Click me!,它执行了一个脚本my_button.js,然后来看一下这个js脚本的内容,

exports.execute = async (args) => {
  // args => http://egodigital.github.io/vscode-powertools/api/interfaces/_contracts_.buttonactionscriptarguments.html
 ​
  // s. http://code.visualstudio.com/api/references/vscode-api
  const vscode = args.require('vscode');
 ​
  vscode.window.showInformationMessage(
  'Hey, you clicked me!'
  );
 };

这个脚本的功能就是弹出一个消息框,下面来看一下效果。

img

命令

为了增强VS Code的功能,可以自定义一个命令,这样的话就可以在VS Code任何位置都可以调用。

和按钮一样,需要首先配置一下settings.json,

{
  "ego.power-tools": {
  "commands": {
  "myCommand": {
  "script": "my_command.js",
  "button": {
  "text": "Click here to start the command."
  }
  }
  }
  }
 }

然后,创建一个js脚本,

 exports.execute = async (args) => {
  // args => http://egodigital.github.io/vscode-powertools/api/interfaces/_contracts_.workspacecommandscriptarguments.html
 ​
  // s. http://code.visualstudio.com/api/references/vscode-api
  const vscode = args.require('vscode');
 ​
  vscode.window.showInformationMessage(
  `Hello, from '${ args.command }'!`
  );
 };

下面来看一下效果,

img

详细的函数列表可以使用命令$help查看,也可以访问链接[2]了解一下。

事件

我觉得这是powertools这些功能中较为实用的一项,通过配置powertools,可以对我们在vs code中的一系列事件作出相应的反应。例如,当文件修改或者删除时能够提示到开发人员。

下面来看一下例子,

{
  "ego.power-tools": {
  "events": [
  {
  "type": "file.changed",
  "files": [ "**/*.txt" ],
  "exclude": [ "/test2.txt" ],
  "action": {
  "script": "my_event.js",
  "type": "script"
  }
  }
  ]
  }
 }

然后是脚本my_event.js,

exports.execute = async (args) => {
  // args => http://egodigital.github.io/vscode-powertools/api/interfaces/_contracts_.filechangeeventactionscriptarguments.html
 ​
  const path = require('path');
 ​
  // s. http://code.visualstudio.com/api/references/vscode-api
  const vscode = args.require('vscode');
 ​
  vscode.window.showInformationMessage(
  `The following file has changed: ${ 
  path.relative(
  __dirname + '/..',
  args.file.fsPath
  )
  }`
  );
 };

这样,当文件修改时,就会得到相应的提示,下面看一下演示效果,

img

工具

重头戏来了!

前面提到的那些功能还是存在一定的门槛,对于喜欢尝试和挑战的同学是不错的功能。但是,对于仅仅想体验它功能的同学却显得枯燥乏味。

既然,powertools能够称得上插件领域的瑞士军刀,那么它当然不能仅包含前面这些功能。

powertools内置了很多丰富而且实用的函数模块,这些函数的使用方式分为如下几个步骤:

  1. 点击按键F1或者Ctrl+Shift+P

  2. 选择Power Tools: Tools

  3. 选择Code Execution ...

然后就可以输入对应的函数即可。

powertools支持哪些函数?

执行上述1~3步,然后输入$help,就可以列出powertools支持的函数列表。

因为,powertools支持的函数和模块较多,无法一一介绍,所以就挑3个介绍一下。

计算器

执行前面1~3步,输入需要计算的数学公式就可以弹出计算结果,

img

Base64编码

Base64是网络上最常见的用于传输8Bit字节码的编码方式之一,在数据的加解密中经常会用到。在powertools中能够轻松的对字符串进行Base64编码。

示例

$base64("mkloubert:P@ssword123!")

img

搜索表情

输入对应的关键字,powertools就可以返回相关emojis表情列表。

示例

$emojis("heart")

img

除了本文介绍的应用、按钮、命令、事件、工具这些功能,powertools还可以用于执行定时作业脚本启动、用于定义动态设置的占位符,感兴趣的同学可以摸索尝试一下这些功能。

结语

大家有什么要说的,欢迎在评论区留言

对了,小编为大家准备了一套2020最新的web前端资料,需要点击下方链接获取方式

1、点赞+评论(勾选“同时转发”)

学习前端,你掌握这些。二线也能轻松拿8K以上

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