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

VSCode进阶之路

VSCode进阶之路:从入门到高效率开发

🚀 Hey,朋友们好!还在为VSCode的海量功能感到眼花缭乱吗?咱们一起来解锁VSCode的超神技能吧!

开篇碎碎念 🎯

第一次用VSCode时,就像个闯入魔法世界的麻瓜,面对满屏的快捷键和命令面板一脸懵逼。经过摸爬滚打,终于从一个"记事本选手"进化成了"VSCode法师"。

今天,咱们一起突破VSCode的进阶之路!

第一关:从基础配置开始 ⚙️

1. 界面布局大改造

兄弟们,第一件事,我们得把VSCode打扮得漂漂亮亮的,不然写代码没心情啊!

{"workbench.colorTheme": "One Dark Pro","editor.fontSize": 14,"editor.fontFamily": "JetBrains Mono","editor.fontLigatures": true,"workbench.iconTheme": "material-icon-theme","editor.minimap.enabled": true,"editor.cursorSmoothCaretAnimation": true,"editor.smoothScrolling": true,"workbench.list.smoothScrolling": true
}

💡 小贴士:JetBrains Mono这个字体是我用过最舒服的编程字体,连字特性简直不要太赞!而且最近的更新增加了更多连字支持,代码看起来更加优雅。

2. 必装插件套餐

开发效率神器
  • GitLens - Git可视化简直是神器,查看代码历史记录如翻书般轻松
  • Auto Rename Tag - 前端开发必备,改标签爽到飞起
  • ESLint + Prettier - 代码格式化双胞胎,代码风格统一不再是难题
  • Remote - SSH - 远程开发从未如此简单,服务器开发像本地一样流畅
  • Thunder Client - 接口测试的轻量级选择,比Postman启动快多了
前端开发必备
  • CSS Peek - 直接从HTML跳转到CSS定义
  • Color Highlight - 颜色代码直接显示对应的颜色
  • Import Cost - 显示引入包的大小,优化性能必备
  • JavaScript (ES6) code snippets - ES6代码片段
AI辅助编程
  • GitHub Copilot - AI配对编程,提高编码效率
  • Tabnine AI - 智能代码补全,学习你的编码风格

🎈 插件小贴士:别贪多!安装太多插件会影响VSCode的启动速度。建议根据实际开发需求安装,不用的及时禁用。

第二关:快捷键称霸天下 ⌨️

必记快捷键清单

快捷键功能使用场景和技巧
Ctrl + Shift + P命令面板万能入口,记不住快捷键就用它
Ctrl + P文件快速跳转大项目文件检索神器,支持模糊匹配
Alt + ↑/↓行移动代码重构时的效率神器
Ctrl + D多光标选择批量修改必备技能
Ctrl + K + S保存所有文件强迫症患者必备
Ctrl + Shift + L选择所有相同词比替换更精确的批量修改
Ctrl + B侧边栏显示/隐藏快速获得更多编码空间

高级快捷键技巧

  1. 组合技

    • Ctrl + L 连续按:逐行选择
    • Alt + Click:添加多个光标
    • Ctrl + Shift + K:删除整行
  2. 自定义快捷键

{"key": "ctrl+alt+/","command": "editor.action.blockComment","when": "editorTextFocus && !editorReadonly"
}

🎮 练习建议:建一个专门的练习文件,每天花10分钟专门练习快捷键。一个月后,你会发现自己完全离不开这些快捷键了!

第三关:代码片段自动化 🤖

1. Vue3组件模板

{"Vue3 Template": {"prefix": "v3","body": ["<template>","  <div class=\"${1:component-name}\">","    $2","  </div>","</template>","","<script setup lang=\"ts\">","import { ref, onMounted } from 'vue'","","const props = defineProps<{","  ${3:propName}: ${4:string}","}>())","","const ${5:data} = ref(${6:null})","","onMounted(() => {","  $7","})","</script>","","<style scoped lang=\"scss\">",".${1:component-name} {","  $8","}","</style>"],"description": "Vue3 setup template with TypeScript"}
}

2. React组件模板

{"React Functional Component": {"prefix": "rfc","body": ["import React from 'react'","","interface ${1:${TM_FILENAME_BASE}}Props {","  ${2:prop}: ${3:type}","}","","export const ${1:${TM_FILENAME_BASE}} = ({ ${2:prop} }: ${1:${TM_FILENAME_BASE}}Props) => {","  return (","    <div>","      $4","    </div>","  )","}",""],"description": "React Functional Component with TypeScript"}
}

💡 进阶提示:代码片段还支持正则表达式和变量替换,可以实现更复杂的自动化。

第四关:工作区配置大法 🎯

多项目工作区配置

{"folders": [{"path": "frontend","name": "前端项目"},{"path": "backend","name": "后端服务"},{"path": "docs","name": "项目文档"}],"settings": {"[javascript]": {"editor.defaultFormatter": "esbenp.prettier-vscode","editor.formatOnSave": true,"editor.tabSize": 2},"[python]": {"editor.defaultFormatter": "ms-python.python","editor.formatOnSave": true,"editor.tabSize": 4},"[markdown]": {"editor.defaultFormatter": "yzhang.markdown-all-in-one","editor.formatOnSave": true}},"launch": {"configurations": [],"compounds": []}
}

项目特定设置

在项目根目录创建 .vscode/settings.json

{"search.exclude": {"**/node_modules": true,"**/dist": true},"files.watcherExclude": {"**/node_modules/**": true,"**/dist/**": true},"editor.codeActionsOnSave": {"source.fixAll.eslint": true}
}

第五关:Debug不求人 🐛

1. 断点进阶技巧

  • 条件断点:右键断点 → 编辑断点 → 设置条件
// 示例:当循环索引为5时触发断点
for(let i = 0; i < 10; i++) {if(someCondition) {  // 设置条件:i === 5doSomething();}
}
  • 日志点:右键行号 → 添加日志点
// 不用修改代码就能打印日志
getMessage() {  // 添加日志点:'返回消息:{message}'return message;
}

2. Launch配置进阶

{"version": "0.2.0","configurations": [{"type": "node","request": "launch","name": "启动服务","program": "${workspaceFolder}/server.js","env": {"NODE_ENV": "development"},"preLaunchTask": "npm: build","postDebugTask": "notify-debug-finished"}]
}

第六关:Git集成玩法 🌳

1. 内置Git功能增强

{"git.enableSmartCommit": true,"git.confirmSync": false,"git.autofetch": true,"git.pruneOnFetch": true
}

2. GitLens进阶配置

{"gitlens.codeLens.enabled": true,"gitlens.currentLine.enabled": true,"gitlens.hovers.currentLine.over": "line","gitlens.statusBar.enabled": true
}

彩蛋:我的私藏技巧 🎁

1. 任务自动化

{"version": "2.0.0","tasks": [{"label": "开发环境启动","type": "shell","command": "npm run dev & npm run mock","problemMatcher": []},{"label": "部署流程","dependsOn": ["构建","测试","部署"],"group": {"kind": "build","isDefault": true}}]
}

2. 实用配置技巧

{// 自动保存"files.autoSave": "afterDelay","files.autoSaveDelay": 1000,// 编辑器优化"editor.bracketPairColorization.enabled": true,"editor.guides.bracketPairs": true,// 终端优化"terminal.integrated.defaultProfile.windows": "Git Bash","terminal.integrated.fontFamily": "MesloLGS NF",// 搜索优化"search.smartCase": true,"search.useGlobalIgnoreFiles": true
}

3. 终端集成技巧

  1. 配置集成终端
{"terminal.integrated.profiles.windows": {"Git Bash": {"path": ["C:\\Program Files\\Git\\bin\\bash.exe"],"icon": "terminal-bash"}}
}
  1. 任务运行器配置
{"version": "2.0.0","tasks": [{"label": "Monitor Changes","type": "shell","command": "watch","args": ["npm", "run", "test"],"group": "test","presentation": {"reveal": "always","panel": "new"}}]
}

总结一下 📝

VSCode就像一把瑞士军刀,关键是要用对方法。通过这篇教程的六大关卡,相信你已经掌握了:

  • 基础配置优化
  • 效率插件运用
  • 快捷键进阶
  • 代码片段自动化
  • 工作区管理
  • 调试技巧
  • Git集成应用

记住,工具永远是提升效率的手段,而不是目的。持续学习和实践才是提升编程效率的王道!

下期预告 🔮

下一篇我们将深入探讨IDEA的独家秘籍,让Java开发效率再上新台阶!敬请期待!


🤝 交流时间:你有什么VSCode使用秘籍?欢迎在评论区分享!

如果觉得有帮助,别忘了点个赞哦!你的支持是我创作的最大动力!

相关文章:

VSCode进阶之路

VSCode进阶之路&#xff1a;从入门到高效率开发 &#x1f680; Hey&#xff0c;朋友们好&#xff01;还在为VSCode的海量功能感到眼花缭乱吗&#xff1f;咱们一起来解锁VSCode的超神技能吧&#xff01; 开篇碎碎念 &#x1f3af; 第一次用VSCode时&#xff0c;就像个闯入魔法世…...

leetcode-21-合并两个有序链表

题解&#xff1a; 1、初始化哑节点dum 2、 3、 代码&#xff1a; 参考&#xff1a;leetcode-88-合并两个有序数组...

SSM项目部署到服务器

将SSM&#xff08;Spring Spring MVC MyBatis&#xff09;项目部署到服务器上&#xff0c;通常需要以下步骤&#xff1a; 打包项目 生成一个WAR文件&#xff0c;通常位于target目录下 配置Tomcat&#xff1a; 将生成的WAR文件复制到Tomcat的webapps目录下。 配置conf/se…...

【Linux】网络编程:初识协议,序列化与反序列化——基于json串实现,网络通信计算器中简单协议的实现、手写序列化与反序列化

目录 一、什么是协议&#xff1f; 二、为什么需要有协议呢&#xff1f; 三、协议的应用 四、序列化与反序列化的引入 什么是序列化和反序列化&#xff1f; 为什么需要序列化和反序列化&#xff1f; 五、序列化推荐格式之一&#xff1a;JSON介绍 六、网络版计算器编程逻…...

Educational Codeforces Round 171 (Rated for Div. 2)(A~D) 题解

Problem - A - Codeforces--PerpendicularSegments 思路:正方形对角线最长,并且相互垂直.直接输出即可. int x,y,k; void solve(){ //Acin>>x>>y>>k;int resmin(x,y);cout<<"0 0"<<" "<<res<<" &q…...

【教程】Git 标准工作流

目录 前言建仓&#xff0c;拉仓&#xff0c;关联仓库修改代码更新本地仓库&#xff0c;并解决冲突提交代码&#xff0c;合入代码其他常用 Git 工作流删除本地仓库和远程仓库中的文件日志打印commit 相关 前言 Git 是日常开发中常用的版本控制工具&#xff0c;配合代码托管仓库…...

Nico,从零开始干掉Appium,移动端自动化测试框架实现

开头先让我碎碎念一波~去年差不多时间发布了一篇《 UiAutomator Nico&#xff0c;一个基于纯 adb 命令实现的安卓自动化测试框》&#xff08;https://testerhome.com/topics/37042&#xff09;&#xff0c; 由于种种原因 (详见此篇帖子) 当时选择了用纯 adb 命令来实现安卓自动…...

PHP合成图片,生成海报图,poster-editor使用说明

之前写过一篇使用Grafika插件生成海报图的文章&#xff0c;但是当我再次使用时&#xff0c;却发生了错误&#xff0c;回看Grafika文档&#xff0c;发现很久没更新了&#xff0c;不兼容新版的GD&#xff0c;所以改用了intervention/image插件来生成海报图。 但是后来需要对海报…...

微信小程序 - 数组 push / unshift 追加后数组返回内容为数字(数组添加后打印结果为 Number 数值类型)

前言 假设一个空数组,通过 push 方法追加了一个项,控制台打印的结果竟然是 Number 数值。 例如,以下微信小程序代码: // 源数组 var arr = [] // 追加数据 var tem = arr.push(数据)...

1、DevEco Studio 鸿蒙仓颉应用创建

1. 仓颉鸿蒙应用简介 因为仓颉是静态编译型语言&#xff0c;使用仓颉开发的应用执行效率更高。而且主打全场景&#xff0c;后续可并入仓颉生态&#xff0c;其和ArkTS都是基于ArkUI进行开发&#xff0c;最大的区别是typescript和仓颉语法间的差异。 2. 应用创建 前置条件&…...

从头开始学PHP之面向对象

首先介绍下最近情况&#xff0c;因为最近入职了且通勤距离较远&#xff0c;导致精力不够了&#xff0c;而且我发现&#xff0c;人一旦上了班&#xff0c;下班之后就不想再进行任何脑力劳动了&#xff08;对大部分牛马来说&#xff0c;精英除外&#xff09;。 话不多说进入今天的…...

C++ | Leetcode C++题解之第519题随机翻转矩阵

题目&#xff1a; 题解&#xff1a; class Solution { public:Solution(int m, int n) {this->m m;this->n n;this->total m * n;srand(time(nullptr));}vector<int> flip() {int x rand() % total;vector<int> ans;total--; // 查找位置 x 对应的…...

vrrp和mstp区别

思路 vrrp是用来虚拟网关&#xff0c;噢&#xff0c;是虚拟一条虚拟网关 优先级&#xff0c;priority越大越优先&#xff0c;优先级相同&#xff0c;哪个的路由器的vrrp先起来&#xff0c;谁就是主 mstp是快速生成树协议&#xff0c;防止环路用的 优先级越小越优先 华为命令…...

前端页面整屏滚动fullpage.js简单使用

官网CSS,JS地址 fullPage.js/dist/fullpage.min.js at master alvarotrigo/fullPage.js GitHub fullPage.js/dist/fullpage.min.css at master alvarotrigo/fullPage.js GitHub <!DOCTYPE html> <html lang"en"><head><meta charset"…...

JQuery基本介绍和使用方法

JQuery基本介绍和使用方法 W3C 标准给我们提供了⼀系列的函数, 让我们可以操作: ⽹⻚内容⽹⻚结构⽹⻚样式 但是原⽣的JavaScript提供的API操作DOM元素时, 代码⽐较繁琐, 冗⻓. 我们可以使⽤JQuery来操作⻚⾯对象. jQuery是⼀个快速、简洁且功能丰富的JavaScript框架, 于20…...

【案例】旗帜飘动

开发平台&#xff1a;Unity 6.0 开发工具&#xff1a;Shader Graph 参考视频&#xff1a;Unity Shader Graph 旗帜飘动特效   一、效果图 二、Shader Graph 路线图 三、案例分析 核心思路&#xff1a;顶点偏移计算 与 顶点偏移忽略 3.1 纹理偏移 视觉上让旗帜保持动态飘动&a…...

大模型思维链推理的综述:进展、前沿和未来

转自公众号AIRoobt A Survey of Chain of Thought Reasoning: Advances, Frontiers and Future 思维链推理的综述&#xff1a;进展、前沿和未来 摘要&#xff1a;思维链推理&#xff0c;作为人类智能的基本认知过程&#xff0c;在人工智能和自然语言处理领域引起了极大的关注…...

项目一:使用 Spring + SpringMVC + Mybatis + lombok 实现网络五子棋

一&#xff1a;系统展示: 二&#xff1a;约定前后端接口 2.1 登陆 登陆请求&#xff1a; GET /login HTTP/1.1 Content-Type: application/x-www-form-urlencodedusernamezhangsan&password123登陆响应&#xff1a; 正常对象&#xff1a;正常对象会在数据库中存储&…...

openEuler 系统中 Samba 文件共享服务器管理(windows、linux文件共享操作方法)

一、Samba 简介 Samba 是在 Linux 和 Unix 系统上实现 SMB/CIFS 协议的一个免费软件&#xff0c;使得这些系统可以与 Windows 系统进行文件和打印机共享。通过 Samba&#xff0c;可以将 openEuler 系统配置为文件服务器&#xff0c;让 Windows、Linux 和其他支持 SMB/CIFS 协议…...

使用 Elasticsearch 进行语义搜索

Elasticsearch 是一款功能强大的开源搜索引擎&#xff0c;可用于全文搜索、分析和数据可视化。传统上&#xff0c;Elasticsearch 以其执行基于关键字/词汇的搜索的能力而闻名&#xff0c;其中文档基于精确或部分关键字匹配进行匹配。然而&#xff0c;Elasticsearch 已经发展到支…...

7.4.分块查找

一.分块查找的算法思想&#xff1a; 1.实例&#xff1a; 以上述图片的顺序表为例&#xff0c; 该顺序表的数据元素从整体来看是乱序的&#xff0c;但如果把这些数据元素分成一块一块的小区间&#xff0c; 第一个区间[0,1]索引上的数据元素都是小于等于10的&#xff0c; 第二…...

linux之kylin系统nginx的安装

一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源&#xff08;HTML/CSS/图片等&#xff09;&#xff0c;响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址&#xff0c;提高安全性 3.负载均衡服务器 支持多种策略分发流量…...

应用升级/灾备测试时使用guarantee 闪回点迅速回退

1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间&#xff0c; 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点&#xff0c;不需要开启数据库闪回。…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

如何在看板中有效管理突发紧急任务

在看板中有效管理突发紧急任务需要&#xff1a;设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP&#xff08;Work-in-Progress&#xff09;弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中&#xff0c;设立专门的紧急任务通道尤为重要&#xff0c;这能…...

使用 SymPy 进行向量和矩阵的高级操作

在科学计算和工程领域&#xff0c;向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能&#xff0c;能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作&#xff0c;并通过具体…...

在QWebEngineView上实现鼠标、触摸等事件捕获的解决方案

这个问题我看其他博主也写了&#xff0c;要么要会员、要么写的乱七八糟。这里我整理一下&#xff0c;把问题说清楚并且给出代码&#xff0c;拿去用就行&#xff0c;照着葫芦画瓢。 问题 在继承QWebEngineView后&#xff0c;重写mousePressEvent或event函数无法捕获鼠标按下事…...

无人机侦测与反制技术的进展与应用

国家电网无人机侦测与反制技术的进展与应用 引言 随着无人机&#xff08;无人驾驶飞行器&#xff0c;UAV&#xff09;技术的快速发展&#xff0c;其在商业、娱乐和军事领域的广泛应用带来了新的安全挑战。特别是对于关键基础设施如电力系统&#xff0c;无人机的“黑飞”&…...

关于uniapp展示PDF的解决方案

在 UniApp 的 H5 环境中使用 pdf-vue3 组件可以实现完整的 PDF 预览功能。以下是详细实现步骤和注意事项&#xff1a; 一、安装依赖 安装 pdf-vue3 和 PDF.js 核心库&#xff1a; npm install pdf-vue3 pdfjs-dist二、基本使用示例 <template><view class"con…...

论文阅读笔记——Muffin: Testing Deep Learning Libraries via Neural Architecture Fuzzing

Muffin 论文 现有方法 CRADLE 和 LEMON&#xff0c;依赖模型推理阶段输出进行差分测试&#xff0c;但在训练阶段是不可行的&#xff0c;因为训练阶段直到最后才有固定输出&#xff0c;中间过程是不断变化的。API 库覆盖低&#xff0c;因为各个 API 都是在各种具体场景下使用。…...