IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> 跟着我实现一个vscode插件(一) -> 正文阅读

[开发工具]跟着我实现一个vscode插件(一)

VScode是使用TypeScript 和 Electron实现的一款非常强大的编辑器,开源免费,轻巧灵便,功能强大。

我之前用过Hbuilder和Webstorm,自从我使用了VScode之后,立即就对他爱不释手了。喜欢它的原因之一就是功能强大,插件特别多,我们在感谢这款编辑器的同时,也要感谢开发VScode插件的那群大佬们!今天我会从0实现一个vscode插件,并应用到项目中去。

安装应用与所需环境

  1. 首先你的电脑上需要VScode与node环境

  2. 然后,需要下载开发插件的环境 Yeoman 和 VS Code Extension generator

  3. 全局安装下这两个插件

    npm install -g yo generator-code
    
  4. 进入要开发的目录

    yo code
    

    开始创建流程
    在这里插入图片描述
    在这里插入图片描述
    5.创建成功后如下图:
    在这里插入图片描述

开始调试

  1. 介绍完目录结构后,我们可以来运行一下看看效果如果。我们打开一个vscode并把我们的fujinting目录自己拖拉到vscode的界面上。
  2. 然后选择调试窗口,并点击开始调试或者直接按快捷键 F5,这时候会弹出一个vscode新窗口,在新窗口ctrl+p 输入>Hello World,点击显示出的,vscode新窗口右下角会弹出如下在这里插入图片描述
    这时候,你可以在生成的extension.js这个文件内写你的代码,尽情发挥你的本领。

打包

我们开发完后,需要打包或发布,这时候我们需要使用一个工具

npm install -g vsce

有两种方式,处理我们开发的插件

  1. 打包成vsix插件,然后发送给别人安装,如果你的插件涉及机密不方便发布到应用市场,可以尝试采用这种方式 (公司业务插件可以这么干);
  2. 注册开发者账号,发布到官网应用市场,这个发布和npm一样是不需要审核的(开源插件,通过vscode商店和网页可以下载的)。

本地打包不发布

  1. 发布命令

    vsce package
    
  2. 上一步有没有报错呢?那是肯定的

    Missing publisher name. Learn more: https://code.visualstudio.com/api/working-with-extensions/publishing-extension#publishing-extension
    

    这意思是要我们, 在package.json中配置发布人: “publisher”:“vscode_publisher_fujt”

    如下:

    {
    	"name": "fujinting",
    	"publisher": "vscode_publisher_fujt",
    	"displayName": "fujinting",
    	"description": "",
    	"version": "0.0.1",
    	"engines": {
    		"vscode": "^1.57.0"
    	},
    	"categories": [
    		"Other"
    	],
    	"activationEvents": [
    		"onCommand:fujinting.helloWorld"
    	],
    	"main": "./extension.js",
    	"contributes": {
    		"commands": [
    			{
    				"command": "fujinting.helloWorld",
    				"title": "Hello World"
    			}
    		]
    	},
    	"scripts": {
    		"lint": "eslint .",
    		"pretest": "npm run lint",
    		"test": "node ./test/runTest.js"
    	},
    	"devDependencies": {
    		"@types/vscode": "^1.57.0",
    		"@types/glob": "^7.1.3",
    		"@types/mocha": "^8.2.2",
    		"@types/node": "14.x",
    		"eslint": "^7.27.0",
    		"glob": "^7.1.7",
    		"mocha": "^8.4.0",
    		"typescript": "^4.3.2",
    		"vscode-test": "^1.5.2"
    	}
    }
    
    
  3. 再次 vsce package,又报错了,如下

    Error:Make sure to edit the README.md file before you publish your extension
    

    把README.md删干净,添加如下内容

    welcome to my first vscode plugin !
    
  4. 再次vsce package

    提示:

    Do you want to continue? [y/N]
    
  5. 终于成功了

    在这里插入图片描述

  6. 在应用商店导入即可
    在这里插入图片描述

开发流程

下篇文章详细介绍

发布线上

失败了,感兴趣的小伙伴可以看下

  1. 我们去注册publisher账号
    创建microsoft账号 在这里创建https://login.live.com/,我之前创建过,直接登录了
    在这里插入图片描述

  2. 访问 https://aka.ms/SignupAzureDevOps,创建一个组织,管他什么组织,建就完了在这里插入图片描述

  3. 创建令牌 点击右上角的小人,选择里面的Personal access tokens
    在这里插入图片描述
    在这里插入图片描述
    点击创建,生成token,找个地方保存下来
    在这里插入图片描述

  4. 去你开发的目录下执行创建发布人的命令: vsce create-publisher vscode_pluginer_fujt
    报错:

    The 'create-publisher' command is no longer available. You can create a publisher directly in the Marketplace: https://aka.ms/vscode-create-publisher
    
    这里create-publisher可以通过命令行创建发布用户的,但是不知为何删除了,只能通过网页
    
  5. 那我们去网页 https://aka.ms/vscode-create-publisher,注册及成功注册后如下:
    在这里插入图片描述
    在这里插入图片描述

成功创建后,发布:

vsce publish

又报错了

The Personal Access Token verification has failed. Additional information:

Error: Access Denied: 22ddd543-6e12-664c-b5be-f01ccf0193de needs the following permission(s) on the resource /fujinting to perform this action: View user permissions on a resource

解决不了,谷歌百度github都找不到解决方法(应该是权限问题),尽力了,淦他娘
有大佬有办法解决告诉我一下,感谢。

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2021-07-10 14:42:54  更:2021-07-10 14:44:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/5 5:12:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码