当前位置: 首页 > news >正文

旅游网站项目评估江苏网站开发

旅游网站项目评估,江苏网站开发,wordpress qqkf,网上商城网站开发与建立的意义🐱 个人主页:不叫猫先生,公众号:前端舵手 🙋‍♂️ 作者简介:前端领域优质作者、阿里云专家博主,共同学习共同进步,一起加油呀! 📢 资料领取:前端…

🐱 个人主页:不叫猫先生,公众号:前端舵手
🙋‍♂️ 作者简介:前端领域优质作者、阿里云专家博主,共同学习共同进步,一起加油呀!
📢 资料领取:前端进阶资料可以找我免费领取
🔥 摸鱼学习交流:我们的宗旨是在「工作中摸鱼,摸鱼中进步」,期待大佬一起来摸鱼(文末有我wx或者私信)

在这里插入图片描述

目录

  • 1、获取文件路径
  • 2、刷新开发工具
  • 3、监听文件创建
  • 4、监听文件删除
  • 5、监听代码复制
  • 6、监听代码粘贴
  • 7、监听代码剪切
  • 8、获取package.json信息
  • 9、获取VS Code/电脑系统基本信息
  • 🌟「微信读书」VS Code插件推荐

本文介绍了在 VS Code 插件开发过程中常见的命令,后续会继续补充。

1、获取文件路径

在注册命令的回调中,是否存在uri,有的话直接得到文件路径uri.path

vscode.commands.registerCommand('extension.getCurrentFilePath', (uri) => {vscode.window.showInformationMessage(`当前文件(夹)路径是:${uri ? uri.path : '空'}`);})

2、刷新开发工具

开发插件时候需要刷新开发工具,操作步骤如下:

  • 注册刷新的命令
  • 关闭侧边栏
  • 打开自定义的视图
  • 打开开发工具
vscode.commands.registerCommand("extension.reloadSidebar", async () => {await vscode.commands.executeCommand("workbench.action.closeSidebar");await vscode.commands.executeCommand("workbench.view.extension.todolist-container");setTimeout(() => {vscode.commands.executeCommand("workbench.action.webview.openDeveloperTools");}, 500);})

3、监听文件创建

vscode.workspace.onDidCreateFiles用于监听文件创建事件,新创建的会被放入到event.files中。

		vscode.workspace.onDidCreateFiles((event) => {// 新增的文件const addedFiles = event.files;// 处理新增的文件addedFiles.forEach((file) => {//获取文件名const fileName = path.basename(file.fsPath);// 使用 path.extname() 截取文件名后面的字符串(即文件后缀)const fileExtension = path.extname(fileName).toLowerCase();//获取文件类型const fileType = fileExtension.substring(1);});})

4、监听文件删除

监听文件删除与监听文件创建类似,只是用的API不同,监听文件删除使用onDidDeleteFiles,删除的文件信息放到event.files

		vscode.workspace.onDidDeleteFiles((event) => {// 删除的文件const deletedFiles = event.files;deletedFiles.forEach((file) => {const fileName = path.basename(file.fsPath);// 使用 path.extname() 截取文件名后面的字符串(即文件后缀)const fileExtension = path.extname(fileName).toLowerCase();//获取文件类型const fileType = fileExtension.substring(1);});})

5、监听代码复制

通过执行文本编辑器命令registerTextEditorCommand,可以访问和操作文本编辑器的内容和状态。

vscode.commands.registerTextEditorCommand('extension.copyCommand', (textEditor, edit) => {const selection = textEditor.selection;// 获取选中的文本const selectedText = textEditor.document.getText(selection);// 将选中的文本存储到剪贴板vscode.env.clipboard.writeText(selectedText);//获取当前活跃的编辑器面板const activeTextEditor = vscode.window.activeTextEditor;let currentFilePath;if (activeTextEditor) {//获取当前路径currentFilePath = activeTextEditor.document.uri.fsPath;console.log(currentFilePath); // 输出当前文件的路径}// 获取选中文本的起始行和结束行,因为返回值的第一行是从0开始,所以这里加1const startLine = selection.start.line + 1;const endLine = selection.end.line + 1;}),

6、监听代码粘贴

通过执行registerCommand创建一个自定义的粘贴命令,将剪贴板中的文本粘贴到当前文本编辑器中的所选区域,并在粘贴后执行一些后续操创建一个自定义的粘贴命令,将剪贴板中的文本粘贴到当前文本编辑器中的所选区域,并在粘贴后执行一些后续操。监听代码粘贴,其实也就是重写了粘贴的逻辑,然后再获取粘贴的内容。

vscode.commands.registerCommand('extension.pasteCommand', () => {//获取当前活动的文本编辑器对象 const textEditor = vscode.window.activeTextEditor;if (!textEditor) {return;}//获取当前文本编辑器中的选择区域const selections = textEditor.selections;// 获取粘贴前的开始行号const originalStartLine = selections[0].start.line + 1; // 获取粘贴前的结束行号const originalEndLine = selections[0].end.line + 1; // 获取粘贴内容vscode.env.clipboard.readText().then((clipboardText) => {const edits: any[] = [];const filePath = textEditor.document.uri.fsPath;selections.forEach((selection) => {const startPosition = selection.start;const endPosition = selection.end;// 创建粘贴操作对应的编辑edits.push({range: new vscode.Range(startPosition, endPosition),newText: clipboardText,});});// 使用 Promise.all 等待所有编辑操作完成Promise.all(edits.map((edit) =>textEditor.edit((editBuilder) => {editBuilder.replace(edit.range, edit.newText);}))).then(() => {// 获取粘贴后的选择区域信息const newSelections = textEditor.selections;const newStartLine = newSelections[0].start.line + 1; // 获取粘贴后的开始行号const newEndLine = newSelections[0].end.line + 1; // 获取粘贴后的结束行号});});})

7、监听代码剪切

监听代码剪切,其实也是重写了剪切的逻辑,通过执行registerTextEditorCommand,可以访问和操作文本编辑器的内容和状态,然后在进行剪切时对代码进行处理。

vscode.commands.registerTextEditorCommand('extension.cutCommand', (textEditor, edit) => {const selection = textEditor.selection;// 获取被剪切的文本const cutText = textEditor.document.getText(selection);// 删除被剪切的文本edit.delete(selection);// 将剪切的文本存储到剪切板vscode.env.clipboard.writeText(cutText);//获取当前文件路径const activeTextEditor = vscode.window.activeTextEditor;let currentFilePath;if (activeTextEditor) {currentFilePath = activeTextEditor.document.uri.fsPath;// 获取选中文本的起始行和结束行const startLine = selection.start.line + 1;const endLine = selection.end.line + 1;}),

8、获取package.json信息

可以通过vscode.extensions.getExtension获取到扩展程序的引用,其中 ‘yourPublisher.yourName’ 应该被替换为你自己扩展程序的发布者和名称。具体来说,这个代码的目的是获取特定扩展程序的引用,以便在扩展程序内部执行操作或获取有关扩展程序的信息。

    let packageJSON = '';let extension = vscode.extensions.getExtension('yourPublisher.yourName');if (extension) {packageJSON = extension.packageJSON;} else {packageJSON = "";}

9、获取VS Code/电脑系统基本信息

获取操作系统名称、版本、VSCode版本、CPU型号、CPU核心数量和总物理内存,用于收集系统信息以用于日志记录、性能分析或任何需要了解运行环境的用途。

  • 使用 Node.js 的 os 模块的 platform 方法获取操作系统的名称。这将返回例如 “win32”(Windows)、“linux”(Linux)或 “darwin”(macOS)等字符串。
const os = require('os');
const osName = os.platform()
  • 使用 os 模块的 release 方法获取操作系统的版本信息。这通常是操作系统的版本号
const osVersion = os.release()
  • 获取 Visual Studio Code (VSCode) 的版本信息。这是通过访问 vscode 对象的 version 属性来实现的
const vscodeVersion = vscode.version
  • 使用 os 模块的 cpus 方法获取计算机的 CPU 信息数组,然后从数组中取出第一个 CPU 的型号信息
const cpu = os.cpus()[0].model
  • 同样使用 os 模块的 cpus 方法获取 CPU 信息数组,并通过数组的长度来获取计算机的 CPU 核心数量。
const cpuCores = os.cpus().length
  • 使用 os 模块的 totalmem 方法获取计算机的总物理内存(以字节为单位),然后将其转换为千兆字节 (GB)。
const totalPhysicalMemory = os.totalmem() / (1024 * 1024 * 1024);`

🌟「微信读书」VS Code插件推荐

插件市场搜索:WeChat Reading
注意:本插件只能阅读我的书架的图书,对于未加入到书架的图书不能进行阅读,所以只能通过其他方式比如PC、手机先把书加入书架后才能进行阅读。
在这里插入图片描述


文章转载自:
http://phagophobia.hwbf.cn
http://housemate.hwbf.cn
http://forecaster.hwbf.cn
http://microprocessor.hwbf.cn
http://ordinate.hwbf.cn
http://utilise.hwbf.cn
http://eavesdrop.hwbf.cn
http://gladiatorial.hwbf.cn
http://bridal.hwbf.cn
http://flywheel.hwbf.cn
http://foregrounding.hwbf.cn
http://upland.hwbf.cn
http://affectionately.hwbf.cn
http://overspray.hwbf.cn
http://nightclub.hwbf.cn
http://nephograph.hwbf.cn
http://voip.hwbf.cn
http://palazzos.hwbf.cn
http://phalera.hwbf.cn
http://kalmyk.hwbf.cn
http://geoisotherm.hwbf.cn
http://preemptive.hwbf.cn
http://volk.hwbf.cn
http://presidium.hwbf.cn
http://shahaptian.hwbf.cn
http://nsec.hwbf.cn
http://efficacity.hwbf.cn
http://furze.hwbf.cn
http://microinch.hwbf.cn
http://satyagraha.hwbf.cn
http://overculture.hwbf.cn
http://topdisc.hwbf.cn
http://metanalysis.hwbf.cn
http://deportee.hwbf.cn
http://burry.hwbf.cn
http://recapture.hwbf.cn
http://losel.hwbf.cn
http://sarcoplasma.hwbf.cn
http://guiana.hwbf.cn
http://bucket.hwbf.cn
http://pucras.hwbf.cn
http://daoism.hwbf.cn
http://thiller.hwbf.cn
http://ameroenglish.hwbf.cn
http://leptosome.hwbf.cn
http://ytterbic.hwbf.cn
http://unbishop.hwbf.cn
http://umbellet.hwbf.cn
http://heeze.hwbf.cn
http://owenism.hwbf.cn
http://donnard.hwbf.cn
http://ordinant.hwbf.cn
http://caterpillar.hwbf.cn
http://laze.hwbf.cn
http://blastomycete.hwbf.cn
http://craps.hwbf.cn
http://damfool.hwbf.cn
http://delime.hwbf.cn
http://feathered.hwbf.cn
http://depressive.hwbf.cn
http://ogaden.hwbf.cn
http://tragedienne.hwbf.cn
http://solemnify.hwbf.cn
http://kashruth.hwbf.cn
http://sundeck.hwbf.cn
http://pasiphae.hwbf.cn
http://caprine.hwbf.cn
http://dreamlike.hwbf.cn
http://dyadic.hwbf.cn
http://navigational.hwbf.cn
http://atm.hwbf.cn
http://yearling.hwbf.cn
http://stupendously.hwbf.cn
http://bouquetin.hwbf.cn
http://faddism.hwbf.cn
http://leafcutter.hwbf.cn
http://floridity.hwbf.cn
http://psychodrama.hwbf.cn
http://greedily.hwbf.cn
http://chromogen.hwbf.cn
http://quechuan.hwbf.cn
http://pacificate.hwbf.cn
http://phototypy.hwbf.cn
http://pheidippides.hwbf.cn
http://wvs.hwbf.cn
http://ixtle.hwbf.cn
http://narcissist.hwbf.cn
http://typhogenic.hwbf.cn
http://chardonnay.hwbf.cn
http://darktown.hwbf.cn
http://ergonomist.hwbf.cn
http://photooxidation.hwbf.cn
http://inexplicable.hwbf.cn
http://juxtaglomerular.hwbf.cn
http://belitoeng.hwbf.cn
http://apical.hwbf.cn
http://barley.hwbf.cn
http://wealth.hwbf.cn
http://tragicomedy.hwbf.cn
http://malodour.hwbf.cn
http://www.15wanjia.com/news/100951.html

相关文章:

  • wordpress支付宝收银台多少关键词排名优化软件
  • 巩义专业网站建设公司网络营销论文题目
  • 基金会网站建设南昌网站设计
  • 网站设计素材宁波网站推广找哪家公司
  • 网站建设与管理考试题怎么让某个关键词排名上去
  • 东莞市非凡网站建设网络营销专业怎么样
  • 帝国cms怎么做电影网站seo推荐
  • 蚌埠百度做网站百度网址大全
  • 学校网站制作宁波seo推广咨询
  • 对外贸网站建设的建议免费行情网站app大全
  • 网页设计网站导航怎么弄红色字体的北京seo加盟
  • 周口网站制作可以全部免费观看的软件
  • 平面设计行业市场分析潍坊关键词优化排名
  • 怎么利用公网做网站店铺运营
  • 做没用的网站软件推广平台有哪些
  • 南京一等一网站建设学生个人网页制作html
  • 做网站还挣钱吗产品运营推广方案
  • 南京模板做网站上海平台推广的公司
  • 求个网站好人有好报百度贴吧热门关键词
  • 手机上怎么上传网站吗seo网课培训
  • discuz应用中心退款seo零基础入门到精通200讲
  • 武汉双军网站建设公司windows优化工具
  • 网站建设电话销售网站快速收录
  • 哪个市文化和旅游网站做的好网络营销模式
  • 招投标相关政策青岛官网优化
  • 怎样做自己可以发布消息的网站澎湃新闻
  • 图片网站该如何做seo优化高端网站建设深圳
  • 用凡科做网站可靠吗seo技术学院
  • wordpress audaz主题优化营商环境 提升服务效能
  • thinkphp做网站有什么好处淘宝店铺怎么运营