VSCode进阶之路

news2024/11/5 21:58:09

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 === 5
        doSomething();
    }
}
  • 日志点:右键行号 → 添加日志点
// 不用修改代码就能打印日志
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使用秘籍?欢迎在评论区分享!

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2233845.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

favicon是什么文件?如何制作网站ico图标?

一般我们做网站的话&#xff0c;都会制作一个独特的ico图标&#xff0c;命名为favicon.ico。这个ico图标一般会出现在浏览器网页标题前面。如下图红色箭头所示&#xff1a; 部分博客导航大全也会用到所收录网站的ico图标。比如boke123导航新收录的网站就不再使用网站首页缩略图…

“大跳水”的全新奥迪A3,精准狙击年轻人的心

文/王俣祺 导语&#xff1a;随着传统豪华品牌在国内市场的全面崩盘&#xff0c;奥迪再一次坐不住了。这次&#xff0c;奥迪“割肉”的目标瞄准了被称为“年轻人第一台豪车”的奥迪A3&#xff0c;这款车问世以来&#xff0c;就凭借出色的性能与品质收获了一大批年轻粉丝。如今&a…

两台手机如何提词呢,一台手机后置高清摄像一台手机前置提词+实时监测状态的解决方案来喽

拍视频只会用前置摄像头可不行啊&#xff0c; 后置高清才会更有流量&#xff0c; 你看哦&#xff0c;我用的是后置摄像头拍摄&#xff0c; 然后前面就用来提词&#xff0c; 它不光能提词&#xff0c; 和其他家不一样的是&#xff0c; 还能把后面手机画面投影到前面手机 这样呀&…

[SWPUCTF 2021 新生赛]easy_sql的write up

开启NSSCTF靶场&#xff0c;在浏览器中访问链接&#xff0c;看到让我们输入点什么还有标签页名字提示&#xff1a; "参数是wllm" 直接/?wllm1访问一下&#xff1a; 这里就直接用sqlmap直接爆破了&#xff1a; 查看数据库有哪些&#xff1a; python sqlmap.py -u …

Tr2 CYT2B75使用记录(二):GPIO、串口、CAN(FD)和busoff检测、看门狗和复位原因

目录 概述GPIO串口1.FIFO2.中断 CANFDRX Buffer and FIFO ElementTX Buffer Elementbusoff 检测 看门狗复位原因 待梳理 概述 GPIO 1.如何定位IO的作用 2.读取电平必须为输入模式 串口 熟悉手册串口特性如下&#xff1a; ■ 数据帧大小可从4位编程到16位 ■ STOP位的可编程…

Android13 系统/用户证书安装相关分析总结(二) 如何增加一个安装系统证书的接口

一、前言 接着上回说&#xff0c;最初是为了写一个SDK的接口&#xff0c;需求大致是增加证书安装卸载的接口&#xff08;系统、用户&#xff09;。于是了解了一下证书相关的处理逻辑&#xff0c;在了解了功能和流程之后&#xff0c;发现settings中支持安装的证书&#xff0c;只…

【Java语言】继承和多态(一)

继承 继承就是实现代码的复用&#xff1b;简而言之就是重复的代码作为父类&#xff08;基类或超类&#xff09;&#xff0c;而不同的可以作为子类&#xff08;派生类&#xff09;。如果子类想要继承父类的成员就一定需要extends进行修饰&#xff08;如&#xff1a;&#xff08;…

04_CC2530+Uart串口通信

04_CC2530UART串口通信 串口通信基本概念 串行通信: 数据字节一位位地依次传送的通信方式, 串行通信的速度慢, 但用的传输线条数少, 成本低&#xff0c;适用于远距离的数据传送并行通信: 数据字节的各位同事传送的通信方式, 优点是数据传送速度快, 缺点是占用的传输线条数多,…

【计算机网络安全】湖北大学–DNS欺骗实验

目录 0x00 ettercap-原理 0x01 ettercap-arp欺骗 0x02 ettercap-dns劫持 0x00 ettercap-原理 攻击者冒充域名服务器&#xff0c;然后把查询的IP地址设为攻击者的IP地址。这样的话&#xff0c;用户上网就只能看到攻击者的主页&#xff0c;而不是用户想要取得的网站。 首先&…

雷池社区版新版本功能防绕过人机验证解析

前两天&#xff0c;2024.10.31&#xff0c;雷池社区版更新7.1版本&#xff0c;其中有一个功能&#xff0c;新增请求防重放 更新记录&#xff1a;hhttps://docs.waf-ce.chaitin.cn/zh/%E7%89%88%E6%9C%AC%E6%9B%B4%E6%96%B0%E8%AE%B0%E5%BD%95 仔细研究了这个需求&#xff0c;…

【深度学习基础】深入理解 卷积与卷积核

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;深度学习_十二月的猫的博客-CSDN博客 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 1. 卷积 1.1 …

SpringBoot集成Shiro+Jwt+Redis

1. 概述 首先需要知道为什么使用 ShiroJwtRedis 进行登录认证和权限控制。 1. 为什么用Shiro&#xff1f; 主要用的是 shiro 的登录认证和权限控制功能。 Shiro 参见本栏目文章 &#x1f343;《Shiro实战》 2. 为什么用Jwt&#xff1f; Shiro 默认的 Session 机制来帮助实现…

基于Python的乡村居民信息管理系统【附源码】

基于Python的乡村居民信息管理系统 效果如下&#xff1a; 系统主页面 系统登录页面 管理员主页面 居民管理页面 政务学习页面 土地信息管理页面 个人信息管理页面 居民登陆页面 村委人员主页面 研究背景 随着信息技术的飞速发展和乡村振兴战略的深入实施&#xff0c;传统的乡…

HTML 基础标签——表单标签<form>

文章目录 1. `<form>` 标签:定义表单容器2. `<input>` 标签:多用途输入控件3. `<textarea>` 标签:多行文本输入框4. `<select>` 标签:下拉选择框5. `<option>` 标签:下拉菜单选项6. `<button>` 标签:按钮元素7. `<label>` 标签…

Debian的基本使用

前言 本人撰写的相关文档中&#xff0c;部分技术已经不再提供支持了&#xff08;不得不感慨&#xff0c;菜鸡的个人进步追不上技术更新啊&#xff09;&#xff0c;比如Centos、EasyExcel&#xff0c;虽然说目前仅使用还没有什么问题&#xff0c;但是还是要了解一下备用方案。 …

比亚迪能不能打败特斯拉?

文/孔文清 比亚迪在第三季度的财报发布后&#xff0c;首次在营收上超越了特斯拉&#xff0c;这是电动汽车行业的重要时刻&#xff0c;也反映了中国产业在全球市场中的崛起。 比亚迪在其2024年第三季度财报中首次实现了2011.2亿元的营业收入&#xff0c;相比特斯拉的1793亿元&a…

什么情况下,不推荐建立索引?

一般有以下几种情况不推荐建立索引&#xff1a; 1&#xff09;对于数据量很小的表 当表的数据量很小&#xff08;如几百条记录&#xff09;时&#xff0c;建立索引并不会显著提高查询性能&#xff0c;反而可能增加管理的复杂性&#xff1b; 2&#xff09;频繁更新的表 对于…

深度学习基础知识-残差网络ResNet

目录 一、ResNet 的核心思想&#xff1a;残差学习&#xff08;Residual Learning&#xff09; 二、ResNet 的基本原理 三、ResNet 网络结构 1. 残差块&#xff08;Residual Block&#xff09; ResNet 的跳跃连接类型 2. 网络结构图示 四、ResNet 的特点和优势 五、ResNe…

做反向代购没货源,也能靠“东方玄学”风生水起?

在全球化日益加深的今天&#xff0c;文化的交流与碰撞愈发频繁。近年来&#xff0c;一股神秘的东方力量——风水玄学&#xff0c;在海外社交媒体上悄然走红&#xff0c;成为众多外国友人追捧的新风尚。从TikTok到Instagram&#xff0c;无数华人博主通过分享风水知识、解读玄学饰…

新闻稿件管理:SpringBoot框架实战指南

3系统分析 3.1可行性分析 通过对本新闻稿件管理系统实行的目的初步调查和分析&#xff0c;提出可行性方案并对其一一进行论证。我们在这里主要从技术可行性、经济可行性、操作可行性等方面进行分析。 3.1.1技术可行性 本新闻稿件管理系统采用SSM框架&#xff0c;JAVA作为开发语…