热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

vscode建立一个下拉选框_VSCode插件开发全攻略(八)代码片段、设置、自定义欢迎页...

代码片段代码片段,也叫snippets,相信大家都不陌生,就是输入一个很简单的单词然后一回车带出来很多代码。平时大家也可以直接在vscod

代码片段

代码片段,也叫snippets,相信大家都不陌生,就是输入一个很简单的单词然后一回车带出来很多代码。平时大家也可以直接在vscode中创建属于自己的snippets:

创建代码片段

那么如何在扩展中创建snippets呢?

package.json文件新增如下:

"contributes": {

"snippets": [

{

// 代码片段作用于那种语言

"language": "Javascript",

// 片段文件路径

"path": "./snippets/Javascript.json"

}

]

}

然后创建一个snippets/Javascript.json文件,我们这里先简单点,比如创建一个for循环:

{

"for循环": {

"prefix": "for",

"body": [

"for (const ${2:item} of ${1:array}) {",

"\t$0",

"}"

],

"description": "for循环"

}

}

解释如下:

for循环:snippets的名字;

prefix:输入什么单词触发代码片段;

body:一个数组,存放代码片段的内容,每一行一个字符串;

description:片段的描述;

${1:xxx}占位符,数字表示光标聚焦的顺序,1表示默认光标落在这里,按下回车或者tab跳到2的位置,以此类推,xxx表示此位置的默认值,可省略,比如直接写$3;

效果如下:

示例:ajax

为加深印象我们再来一个ajax的例子:

{

"ajax": {

"prefix": "ajax",

"body": [

"$.ajax({",

" url: '$1',",

" method: '${2:POST}',",

" datatype: 'json',",

" success: data => {",

" $3;",

" },",

" error: err => {",

" $4;",

" }",

"})"

],

"description": "ajax模块"

}

}

效果(图片是直接偷来的,懒得自己截了):

使用TextMate/Sublime Snippets

利用HelloWorld章节中讲到的yo code生成器可以直接将TextMate代码段(.tmSnippets)转换成VScode的Snippets,生成器有一个选项New Code Snippets选项,可让您指向包含多个.tmSnippets文件的文件夹。此外,生成器还支持Sublime片段(.sublime-snippets)。

设置

每一个插件可以创建一个属于自己的专属设置项,这个配置项会出现在系统设置的扩展下面,效果如下:

配置configuration

配置如下:

"contributes": {

"configuration": {

"type": "object",

// 显示在配置页左侧

"title": "Code插件demo",

"properties": {

// 全局唯一的配置ID

"vscodePluginDemo.yourName": {

"type": "string",

"default": "guest",

"description": "你的名字"

},

"vscodePluginDemo.showTip": {

"type": "boolean",

"default": true,

"description": "启动时显示自定义欢迎页"

}

}

}

}

比较简单,就不细讲了。

读取和修改设置

读取:

// 如果没有设置,返回undefined

const result = vscode.workspace.getConfiguration().get('vscodePluginDemo.yourName ');

修改:

// 最后一个参数,为true时表示写入全局配置,为false或不传时则只写入工作区配置

vscode.workspace.getConfiguration().update('vscodePluginDemo.yourName', '前端艺术家', true);

自定义欢迎页

下面结合设置和webview2个章节的知识我们来做一个非常简单的自定义欢迎页。

最终效果如下:

要实现欢迎页,肯定要保证插件在VSCode一打开就在运行,所以activationEvents必须设置成*。

然后创建一个新的打开欢迎页命令:

context.subscriptions.push(vscode.commands.registerCommand('extension.demo.showWelcome', function (uri) {

const panel = vscode.window.createWebviewPanel(

'testWelcome', // viewType

"自定义欢迎页", // 视图标题

vscode.ViewColumn.One, // 显示在编辑器的哪个部位

{

enableScripts: true, // 启用JS,默认禁用

}

);

let global = { panel};

panel.webview.html = getWebViewContent(context, 'src/view/custom-welcome.html');

panel.webview.onDidReceiveMessage(message => {

if (messageHandler[message.cmd]) {

messageHandler[message.cmd](global, message);

} else {

util.showError(`未找到名为 ${message.cmd} 回调方法!`);

}

}, undefined, context.subscriptions);

}));

然后在全局的active方法里面加入以下代码:

const key = 'vscodePluginDemo.showTip';

// 如果设置里面开启了欢迎页显示,启动欢迎页

if (vscode.workspace.getConfiguration().get(key)) {

vscode.commands.executeCommand('extension.demo.showWelcome');

}

在欢迎页我们加一个选项控制:

启动时显示自定义欢迎页

然后监听show:

watch: {

show(nv, ov) {

callVscode({cmd: 'setConfig', key: 'vscodePluginDemo.showTip', value: nv}, null);

}

}

代码很简单,也没啥太多可以讲的。修改复选框的值后可以去设置里面看一下值是否跟着变了。

参考资料



推荐阅读
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
author-avatar
黄可麟66032
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有