插件界的瑞士軍刀,vs code已經無所不能!

来源:https://www.cnblogs.com/coderhf/archive/2020/06/27/13198604.html
-Advertisement-
Play Games

powertools可以稱得上插件界的瑞士軍刀。 相對於VS Code中大多數插件的出現為瞭解決某一項弊端和不足,powertools則聚合了很多強大且實用的功能,能夠增強VS Code的功能,並提升VS Code的使用體驗。 powertools就如同之前使用iOS系統時使用過的一款軟體Workf ...


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以上


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、coalesce函數的用法 1.1 取出第一個不為空的列的數據。 ​ 1.2 coalesce函數裡面的數據類型,必須全部都跟第一列的數據類型一致。 ​ 原因為第一個參數為數值,第二個參數為字元串;可通過轉換數據類型來使用,如下圖: ​ ...
  • 函數參數:lpad( string, padded_length, [ pad_string ] ) 參數說明: string:源字元串; padded_length: 即最終結果返回的字元串的長度;如果最終返回的字元串的長度比源字元串的小,那麼此函數實際上對源串進行截取處理,與substr(str ...
  • 本博客SQL腳本地址:gitee 準備工作 已知有如下4張表: 學生表:student(學號,學生姓名,出生年月,性別) 成績表:score(學號,課程號,成績) 課程表:course(課程號,課程名稱,教師號) 教師表:teacher(教師號,教師姓名) 一、創建資料庫和表 為了演示題目的運行過程 ...
  • 1. 獲取中獎用戶ID,隨機彈出之後集合中就不存在了【set】 2. 存儲活動中中獎的用戶ID,保證同一個用戶不會中獎兩次【set】 3. 存儲粉絲列表,value 為粉絲的用戶ID,score 是關註時間【zset】 4. 存儲學生成績,value 為學生的ID,score 是考試成績【zset】... ...
  • 我們知道數據的存儲和檢索是兩個很重要的功能,當我們的數據量大了,怎麼能快速的檢索數據呢,答案是使用索引,可索引具體的技術實現有很多,選擇哪一種呢,我就以mysql為例記錄下它為什麼選擇了B+樹作為索引的實現方式。 1. 索引簡介 索引是一種用於快速查詢行的數據結構,就像一本書的目錄就是一個索引,如果 ...
  • 前言 本文將帶大家學習使用前端開發神器-charles,從基本的下載安裝到常見配置使用,為大家一一講解。 一、花式誇獎Charles 截取 Http 和 Https 網路封包。 支持重髮網絡請求,方便後端調試。 支持修改網路請求參數。 支持網路請求的截獲並動態修改。 支持模擬慢速網路。 好,騎上我心 ...
  • 一、堆和棧,數據的存儲方式 1.註意點: JS中是沒有堆和棧的概念,我們用堆和棧來講解,目的就是方柏霓講解,存儲方式是一致的。 2.存儲方式: 基礎數據類型進行值傳遞,複雜數據類型進行地址傳遞 <script> //1.基本數據類型 var str1 = "xiaoliao"; var str2 = ...
  • Web 創建設計 設計一個網站,需要認真思考和規劃。 最重要的是要知道你的訪問用戶。 用戶是瀏覽者 一個典型的訪問者將無法讀取您的網頁的全部內容! 無論您在網頁中發佈了多麼有用的信息,一個訪問者在決定是否繼續閱讀之前僅僅會花幾秒鐘的時間進行瀏覽。 請確保使你的觀點,在頁面的第一句!另外,您還需要在整 ...
一周排行
    -Advertisement-
    Play Games
  • 基於.NET Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...