欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

VSCode插件開(kāi)發(fā)全攻略之package.json詳解

 更新時(shí)間:2020年05月07日 14:33:25   作者:快說(shuō)我是誰(shuí)!  
這篇文章主要介紹了VSCode插件開(kāi)發(fā)全攻略之package.json的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

package.json

在詳細(xì)介紹vscode插件開(kāi)發(fā)細(xì)節(jié)之前,這里我們先詳細(xì)介紹一下vscode插件的package.json寫(xiě)法,但是建議先只需要隨便看一下,了解個(gè)大概,等后面講到具體細(xì)節(jié)的時(shí)候再回過(guò)頭來(lái)看。

如下是package.json文件的常用配置,當(dāng)然這里還不是全部:

{
	// 插件的名字,應(yīng)全部小寫(xiě),不能有空格
 "name": "vscode-plugin-demo",
	// 插件的友好顯示名稱(chēng),用于顯示在應(yīng)用市場(chǎng),支持中文
 "displayName": "VSCode插件demo",
	// 描述
 "description": "VSCode插件demo集錦",
	// 關(guān)鍵字,用于應(yīng)用市場(chǎng)搜索
 "keywords": ["vscode", "plugin", "demo"],
	// 版本號(hào)
 "version": "1.0.0",
	// 發(fā)布者,如果要發(fā)布到應(yīng)用市場(chǎng)的話,這個(gè)名字必須與發(fā)布者一致
 "publisher": "sxei",
	// 表示插件最低支持的vscode版本
 "engines": {
  "vscode": "^1.27.0"
 },
	// 插件應(yīng)用市場(chǎng)分類(lèi),可選值: [Programming Languages, Snippets, Linters, Themes, Debuggers, Formatters, Keymaps, SCM Providers, Other, Extension Packs, Language Packs]
 "categories": [
  "Other"
 ],
	// 插件圖標(biāo),至少128x128像素
 "icon": "images/icon.png",
	// 擴(kuò)展的激活事件數(shù)組,可以被哪些事件激活擴(kuò)展,后文有詳細(xì)介紹
 "activationEvents": [
  "onCommand:extension.sayHello"
 ],
	// 插件的主入口
 "main": "./src/extension",
	// 貢獻(xiàn)點(diǎn),整個(gè)插件最重要最多的配置項(xiàng)
 "contributes": {
		// 插件配置項(xiàng)
		"configuration": {
   "type": "object",
			// 配置項(xiàng)標(biāo)題,會(huì)顯示在vscode的設(shè)置頁(yè)
   "title": "vscode-plugin-demo",
   "properties": {
				// 這里我隨便寫(xiě)了2個(gè)設(shè)置,配置你的昵稱(chēng)
    "vscodePluginDemo.yourName": {
     "type": "string",
     "default": "guest",
     "description": "你的名字"
    },
				// 是否在啟動(dòng)時(shí)顯示提示
    "vscodePluginDemo.showTip": {
     "type": "boolean",
     "default": true,
     "description": "是否在每次啟動(dòng)時(shí)顯示歡迎提示!"
    }
   }
  },
		// 命令
  "commands": [
   {
    "command": "extension.sayHello",
    "title": "Hello World"
   }
  ],
		// 快捷鍵綁定
  "keybindings": [
   {
    "command": "extension.sayHello",
    "key": "ctrl+f10",
    "mac": "cmd+f10",
    "when": "editorTextFocus"
   }
  ],
		// 菜單
  "menus": {
			// 編輯器右鍵菜單
   "editor/context": [
    {
					// 表示只有編輯器具有焦點(diǎn)時(shí)才會(huì)在菜單中出現(xiàn)
     "when": "editorFocus",
     "command": "extension.sayHello",
					// navigation是一個(gè)永遠(yuǎn)置頂?shù)姆纸M,后面的@6是人工進(jìn)行組內(nèi)排序
     "group": "navigation@6"
    },
    {
     "when": "editorFocus",
     "command": "extension.demo.getCurrentFilePath",
     "group": "navigation@5"
    },
    {
					// 只有編輯器具有焦點(diǎn),并且打開(kāi)的是JS文件才會(huì)出現(xiàn)
     "when": "editorFocus && resourceLangId == javascript",
     "command": "extension.demo.testMenuShow",
     "group": "z_commands"
    },
    {
     "command": "extension.demo.openWebview",
     "group": "navigation"
    }
   ],
			// 編輯器右上角圖標(biāo),不配置圖片就顯示文字
   "editor/title": [
    {
     "when": "editorFocus && resourceLangId == javascript",
     "command": "extension.demo.testMenuShow",
     "group": "navigation"
    }
   ],
			// 編輯器標(biāo)題右鍵菜單
   "editor/title/context": [
    {
     "when": "resourceLangId == javascript",
     "command": "extension.demo.testMenuShow",
     "group": "navigation"
    }
   ],
			// 資源管理器右鍵菜單
   "explorer/context": [
    {
     "command": "extension.demo.getCurrentFilePath",
     "group": "navigation"
    },
    {
     "command": "extension.demo.openWebview",
     "group": "navigation"
    }
   ]
  },
		// 代碼片段
  "snippets": [
   {
    "language": "javascript",
    "path": "./snippets/javascript.json"
   },
   {
    "language": "html",
    "path": "./snippets/html.json"
   }
  ],
		// 自定義新的activitybar圖標(biāo),也就是左側(cè)側(cè)邊欄大的圖標(biāo)
  "viewsContainers": {
   "activitybar": [
    {
     "id": "beautifulGirl",
     "title": "美女",
     "icon": "images/beautifulGirl.svg"
    }
   ]
  },
		// 自定義側(cè)邊欄內(nèi)view的實(shí)現(xiàn)
  "views": {
			// 和 viewsContainers 的id對(duì)應(yīng)
   "beautifulGirl": [
    {
     "id": "beautifulGirl1",
     "name": "國(guó)內(nèi)美女"
    },
    {
     "id": "beautifulGirl2",
     "name": "國(guó)外美女"
    },
    {
     "id": "beautifulGirl3",
     "name": "人妖"
    }
   ]
  },
		// 圖標(biāo)主題
  "iconThemes": [
   {
    "id": "testIconTheme",
    "label": "測(cè)試圖標(biāo)主題",
    "path": "./theme/icon-theme.json"
   }
  ]
 },
	// 同 npm scripts
 "scripts": {
  "postinstall": "node ./node_modules/vscode/bin/install",
  "test": "node ./node_modules/vscode/bin/test"
 },
	// 開(kāi)發(fā)依賴(lài)
 "devDependencies": {
  "typescript": "^2.6.1",
  "vscode": "^1.1.6",
  "eslint": "^4.11.0",
  "@types/node": "^7.0.43",
  "@types/mocha": "^2.2.42"
 },
	// 后面這幾個(gè)應(yīng)該不用介紹了
 "license": "SEE LICENSE IN LICENSE.txt",
 "bugs": {
  "url": "https://github.com/sxei/vscode-plugin-demo/issues"
 },
 "repository": {
  "type": "git",
  "url": "https://github.com/sxei/vscode-plugin-demo"
 },
	// 主頁(yè)
 "homepage": "https://github.com/sxei/vscode-plugin-demo/blob/master/README.md"
}

activationEvents

插件在VS Code中默認(rèn)是沒(méi)有被激活的,哪什么時(shí)候才被激活呢?就是通過(guò)activationEvents來(lái)配置,目前支持一下8種配置:

  • onLanguage:${language}
  • onCommand:${command}
  • onDebug
  • workspaceContains:${toplevelfilename}
  • onFileSystem:${scheme}
  • onView:${viewId}
  • onUri
  • *

都比較好懂,我就不做一一介紹了,舉個(gè)例子,如果我配置了onLanguage:javascript,那么只要我打開(kāi)了JS類(lèi)型的文件,插件就會(huì)被激活。

重點(diǎn)說(shuō)一下*,如果配置了*,只要一啟動(dòng)vscode,插件就會(huì)被激活,為了出色的用戶(hù)體驗(yàn),官方不推薦這么做。看到這里相信大家知道了我們前面HelloWord里面為啥要配置onCommand了吧。

3.contributes

  • configuration:設(shè)置
  • commands:命令
  • menus:菜單
  • keybindings:快捷鍵綁定
  • languages:新語(yǔ)言支持
  • debuggers:調(diào)試
  • breakpoints:斷點(diǎn)
  • grammars
  • themes:主題
  • snippets:代碼片段
  • jsonValidation:自定義JSON校驗(yàn)
  • views:左側(cè)側(cè)邊欄視圖
  • viewsContainers:自定義activitybar
  • problemMatchers
  • problemPatterns
  • taskDefinitions
  • colors

參考

extension-manifest

activation-events

貢獻(xiàn)點(diǎn)清單

總結(jié)

到此這篇關(guān)于VSCode插件開(kāi)發(fā)全攻略之package.json詳解的文章就介紹到這了,更多相關(guān)VSCode插件開(kāi)發(fā) package.json內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言線索二叉樹(shù)基礎(chǔ)解讀

    C語(yǔ)言線索二叉樹(shù)基礎(chǔ)解讀

    線索二叉樹(shù)還是按照鏈二叉樹(shù)的方法創(chuàng)建,只不過(guò)在結(jié)點(diǎn)原本為空的左指針改為指向該結(jié)點(diǎn)在中序遍歷中的前驅(qū),結(jié)點(diǎn)原本為空的右指針改為指向該結(jié)點(diǎn)在中序遍歷中的后繼,也就是說(shuō)把空的指針給利用了起來(lái)
    2022-04-04
  • C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生信息管理系統(tǒng)

    C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生信息管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 基于C語(yǔ)言sprintf函數(shù)的深入理解

    基于C語(yǔ)言sprintf函數(shù)的深入理解

    本篇文章是對(duì)C語(yǔ)言中的sprintf函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • QT讀寫(xiě)Sqlite數(shù)據(jù)庫(kù)的三種方式

    QT讀寫(xiě)Sqlite數(shù)據(jù)庫(kù)的三種方式

    Sqlite是一個(gè)比較小型的本地?cái)?shù)據(jù)庫(kù),對(duì)于保存一些軟件配置參數(shù)或量不是很大的數(shù)據(jù)是相當(dāng)?shù)姆奖?Qt本身已經(jīng)自帶了Sqlite的驅(qū)動(dòng),直接使用相關(guān)的類(lèi)庫(kù)即可,這篇我們主要來(lái)說(shuō)明QT訪問(wèn)Sqlite數(shù)據(jù)庫(kù)的三種方式,需要的朋友可以參考下
    2024-03-03
  • c語(yǔ)言鏈表操作示例分享

    c語(yǔ)言鏈表操作示例分享

    這篇文章主要介紹了c語(yǔ)言鏈表操作示例,代碼中有注釋,需要的朋友可以參考下
    2014-03-03
  • C++數(shù)據(jù)模型應(yīng)用在QML委托代理機(jī)制中

    C++數(shù)據(jù)模型應(yīng)用在QML委托代理機(jī)制中

    這篇文章主要介紹了在QML委托代理機(jī)制中使用C++數(shù)據(jù)模型,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • VC創(chuàng)建圓角dialog的實(shí)現(xiàn)方法

    VC創(chuàng)建圓角dialog的實(shí)現(xiàn)方法

    這篇文章主要介紹了VC創(chuàng)建圓角dialog的實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了圓角dialog對(duì)話框的創(chuàng)建步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2016-08-08
  • C++實(shí)現(xiàn)藍(lán)橋杯競(jìng)賽題目---搭積木

    C++實(shí)現(xiàn)藍(lán)橋杯競(jìng)賽題目---搭積木

    這篇文章主要介紹了C++實(shí)現(xiàn)藍(lán)橋杯競(jìng)賽題目---搭積木,本篇文章通過(guò)題目分析列舉公式進(jìn)行分析算法,包含詳細(xì)的圖文,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C/C++中不同數(shù)據(jù)類(lèi)型之間的轉(zhuǎn)換詳解

    C/C++中不同數(shù)據(jù)類(lèi)型之間的轉(zhuǎn)換詳解

    這篇文章主要介紹了C/C++中不同數(shù)據(jù)類(lèi)型之間的轉(zhuǎn)換詳解,數(shù)據(jù)類(lèi)型轉(zhuǎn)換是計(jì)算機(jī)編程中常見(jiàn)的操作,用于將一個(gè)數(shù)據(jù)類(lèi)型轉(zhuǎn)換為另一個(gè)數(shù)據(jù)類(lèi)型,本文將對(duì)不同數(shù)據(jù)類(lèi)型之間的轉(zhuǎn)換作出說(shuō)明,需要的朋友可以參考下
    2023-10-10
  • OpenCV?直方圖均衡化的實(shí)現(xiàn)原理解析

    OpenCV?直方圖均衡化的實(shí)現(xiàn)原理解析

    直方圖均衡化是通過(guò)拉伸像素強(qiáng)度分布范圍來(lái)增強(qiáng)圖像對(duì)比度的一種方法,今天通過(guò)本文給大家介紹OpenCV?直方圖均衡化的實(shí)現(xiàn)原理解析,感興趣的朋友跟隨小編一起看看吧
    2022-01-01

最新評(píng)論