登录
Chainsafe
分类:工具软件 访问:44 下载量:0

软件介绍

更新时间:2025-07-28

Chainsafe:VS Code的可选链操作扩展

Chainsafe是一款专为VS Code设计的扩展工具,旨在帮助开发者在编写TypeScript和JavaScript代码时自动添加可选链操作符(?.)。无论您是通过命令面板操作还是在保存文件时自动添加,Chainsafe都能让您的代码编写过程更加高效和安全。

功能亮点:

  • 自动添加可选链: 通过命令面板或在保存文件时自动添加可选链操作符。
  • 智能检测: 自动识别可能为空的表达式,确保您的代码更健壮。
  • 预览功能: 在差异视图中预览更改,确保您对代码的修改了如指掌。
  • 格式化支持: 支持在保存时自动格式化代码,提升代码质量。
  • 全局保护: 内置对JavaScript全局变量的保护,避免误用可选链。

安装指南:

  1. 打开VS Code。
  2. 按下Ctrl+P / Cmd+P。
  3. 输入ext install vscode-chainsafe并按Enter。
  4. 或者从VS Code Marketplace直接安装。

使用方法:

  • 命令面板: 按Ctrl+Shift+P / Cmd+Shift+P,输入"Add Optional Chaining",即可为当前文件应用可选链。
  • 保存时格式化: 在设置中启用自动格式化:
    {
        "chainsafe.formatOnSave": true
    }

示例:

之前:

const user = getUser();
const name = user.profile.name;
const city = user.profile.address.city;

之后:

const user = getUser();
const name = user?.profile?.name;
const city = user?.profile?.address?.city;

配置选项:

在VS Code的settings.json中进行配置:

{
    "chainsafe.formatOnSave": false,
    "chainsafe.showDiff": true,
    "chainsafe.addToDefaultSkipList": ["axios", "lodash"],
    "chainsafe.removeFromDefaultSkipList": ["Promise", "Array"],
    "chainsafe.skipOnly": ["window", "document"],
    "chainsafe.skipNone": false
}

优先级顺序:

  1. skipNone:如果为true,则对所有内容应用。
  2. skipOnly:如果指定,则仅跳过这些项目。
  3. addToDefaultSkipListremoveFromDefaultSkipList:提供更细粒度的控制。

内置保护全局变量:

默认情况下,以下全局变量受到保护,不会应用可选链:

  • Array
  • Object
  • String
  • Number
  • Boolean
  • Date
  • Math
  • JSON
  • RegExp
  • Error
  • Map
  • Set
  • Promise
  • Function
  • console
  • Buffer

需求:

  • VS Code版本1.94.0或更高
  • 已安装Node.js以支持npx
  • Chainsafe CLI(npm install -g chainsafe)

已知问题:

  • 多个链式操作可能需要多次处理。
  • 大文件处理可能需要更长时间。

发布说明:

0.0.2版本:

  • 添加了对计算属性的处理支持。
  • 改进了对括号表示法访问的检测和转换。
  • 增强了对计算属性表达式的安全检查。
  • 更好地处理动态属性名称。

0.0.1版本:

  • 初始版本发布。
  • 基本的可选链支持。
  • 保存时格式化。
  • 命令面板集成。
  • 差异视图支持。

贡献:

欢迎贡献!您可以通过以下步骤参与:

  1. Fork存储库。
  2. 创建您的功能分支(git checkout -b feature/amazing-feature)。
  3. 提交您的更改(git commit -m 'Add some amazing feature')。
  4. 推送到分支(git push origin feature/amazing-feature)。
  5. 打开拉取请求。

错误报告:

如果您发现错误,请在我们的GitHub问题跟踪器上创建一个问题,并提供:

  • 问题的描述。
  • 重现步骤。
  • 预期行为。
  • 您的环境详情(VS Code版本、操作系统等)。

支持:

如果您喜欢这个扩展,请:

  • ⭐ 在GitHub上给存储库点星。
  • ? 在VS Code Marketplace上评分。
  • ? 在GitHub上报告问题。
  • ? 与他人分享。

许可证:

MIT © Dasari Uma Mahesh

作者:

Dasari Uma Mahesh

  • GitHub
  • LinkedIn

本站所有资源都是由网友投稿发布,或转载各大下载站, 请自行检测软件的完整性!

本站所有资源仅供学习与参考,请勿用于商业用途,否则 产生的一切后果将由您自己承担!

如有侵权请联系我们删除下架,联系方式:study_golang@163.com

最新教程

查看更多
  • Golang云原生架构师课程
    Golang云原生架构师课程
    Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
  • MySQL数据管理之备份恢复案例解析视频教程
    MySQL数据管理之备份恢复案例解析视频教程
    《MySQL数据管理之备份恢复案例解析视频教程》MySQL是一个开放源码的小型关联式数据库管理系统,目前MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。
  • MySQL索引优化解决方案
    MySQL索引优化解决方案
    本套课程是根据MySQL索引的设计理念与数据结构、索引使用场景、索引分类、索引运用场景、索引性能分析、查询优化、MySQL索引的慢查询等组成,主要讲述了MySQL索引优化的解决方案,非常适合有MySQL使用基础或者有一定工作经验的同学。课程讲解了解决大数量查询慢的问题、如何编写一个高效的SQL、查询语句应该如何优化、索引的实现原理是什么、索引又应该如何优化...等诸多SQL索引优化的难点和面试点。
  • 极客学院Docker视频教程
    极客学院Docker视频教程
    Docker是PaaS提供商dotCloud开源的一个基于LXC的高级容器引擎,源代码托管在Github上,基于go语言并遵从Apache2.0协议开源。Docker自2013年以来非常火热,无论是从github上的代码活跃度,还是各大厂商的支持,都使Docker成为了时下最受关注的技术,甚至微软都声称在下一代WindowsServer中集成对Docker的支持。所以我们收集了《极客学院Docke
  • Golang进阶实战编程
    Golang进阶实战编程
    本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
  • JavaScript极速入门
    JavaScript极速入门
    本套课程将帮助大家迅速掌握JavaScript这门高端的、动态的、弱类型编程语言。知识点简单明了,让你学习0压力,适合新手观看学习......