JavaScript 中 Go 风格的错误处理

javascript 中 go 风格的错误处理

几乎每个每天使用 javascript 的人都知道 try-catch 处理起来很痛苦,尤其是当你有多个错误需要处理时。

大多数提出的解决方案都试图复制 golang 的方法 – 将所有内容作为返回值处理。除其他外,它是 go 的一个很棒的功能,但 js 是完全不同的语言(废话),我认为我们可以比 go 的复制粘贴做得更好。

在 go 中,当我们想要处理错误时,我们从函数调用中返回它,或者作为元组中的第二个值,或者作为函数调用的返回值。以下是图案:

result, error := dosomething()if error != nil { // handle error}

登录后复制

这种方法允许使用标准控制流显式处理错误。

要在 javascript 中应用此模式,最常见的解决方案是将结果作为数组返回:

const handler = async (promise) => {  try {    const result = await promise()    return [result, null];  } catch(error) {    return [null, error];  }}const [response, error] = await handle(fetch('http://go.gl'))if (error !== null) {  // handle error}

登录后复制

如您所见,这几乎是直接复制粘贴 go 中的模式。

立即学习“Java免费学习笔记(深入)”;

返回一致的值

这种模式效果很好,但在 javascript 中我们可以做得更好。这种模式的核心思想是将错误作为值返回,所以让我们用更好的 soc 来适应它。

我们可以使用一致的接口来装饰结果,而不是返回 null 或 error。这将改善我们的 soc,并为我们提供强类型的返回值:

interface status {  ok(): boolean;  fail(): boolean;  of(cls: any): boolean;}

登录后复制

接口 status 不一定是 error,但我们可以使用 status.of(error) 检查它的类型。我们总是可以返回一个满足 status 的对象。使用示例是:

const [response, error] = await handle(res.json())if (error.of(syntaxerror)) {  // handle error  console.log("not a json")  return}

登录后复制

现在,在 javascript 中我们的结果并不总是必须是元组。我们实际上可以创建自己的类,在需要时充当元组:

interface iresult {  0: t;  1: status;  value: t;  status: status;  of(cls: any): boolean;  ok(): boolean;  fail(): boolean;}

登录后复制

使用示例:

const result = await handle(res.value.json())if (result.of(syntaxerror)) {  // handle error  console.log("not a json")  return}

登录后复制

实施

按照这种方法,我创建了随时可用的功能 – grip。

grip 是强类型的,可以装饰函数和 promise 等。

我使用 git 来托管此类软件包,因此要安装使用 github:

bun add github:nesterow/grip # or pnpm

登录后复制

用法:

grip 函数接受一个函数或一个 promise,并返回一个带有返回值和状态的结果。
结果可以作为对象或元组处理。

import { grip } from '@nesterow/grip';

登录后复制

将结果作为对象处理:

结果可以作为对象处理:{value, status, ok(), fail(), of(type)}

const res = await grip(  fetch('https://api.example.com'));if (res.fail()) {    handleerrorproperly();    return;}const json = await grip(  res.value.json());if (json.of(syntaxerror)) {    handlejsonparseerror();    return;}

登录后复制

将结果作为元组处理:

如果你想以 go’ish 风格处理错误,结果也可以作为元组接收:

const [res, fetchStatus] = await grip(  fetch('https://api.example.com'));if (fetchStatus.Fail()) {    handleErrorProperly();    return;}const [json, parseStatus] = await grip(  res.json());if (parseStatus.Of(SyntaxError)) {    handleJsonParseError();    return;}

登录后复制

如果您喜欢这种错误处理方式,请查看存储库。源码大约有 50loc,不带类型,100 个带类型。

以上就是JavaScript 中 Go 风格的错误处理的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2664371.html

(0)
上一篇 2025年3月7日 11:37:45
下一篇 2025年3月7日 11:37:50

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 请查看我的项目

    我使用Nextjs和tailwind独立完成了Frontend Mentor的Devjobs项目。有人可以查看项目和/或代码并给我任何反馈吗?我是一个学习者。 部署:https://nextjs-devjobs.vercel.app/ Gi…

    2025年3月7日
    200
  • 破解编码面试:快慢指针技术部分

    在深入研究下一个技术之前,如果您正在准备编码面试并想要全面的资源,请务必探索破解编码面试的十大必备书籍(从初级到高级排名)。对于任何决心在顶级科技公司找到工作的人来说,这都是一本必备的书。 快指针和慢指针技术概述 快慢指针技术(也称为弗洛伊…

    2025年3月7日
    200
  • JUnit 测试:综合指南

    junit 是 java 生态系统中广泛使用的测试框架,旨在帮助开发人员编写和运行可重复的测试。它在确保代码按预期运行方面发挥着至关重要的作用,使其成为维护软件质量的重要工具。凭借其广泛的功能和易用性,junit 已成为 java 单元测试…

    2025年3月7日
    200
  • 注重隐私的在线 PDF 编辑器

    照片来自 Markus Spiske privpdf.com 是 Neural Nirvana 的一个开源项目,旨在优先考虑 PDF 文档的隐私和安全。几乎我们每个人都使用过在线PDF编辑器服务来合并、拆分、编辑、水印PDF文件。但在线操作…

    2025年3月7日
    200
  • 使用 React 和本地存储创建 Notes 应用程序

    您是否希望使用 React 构建一个简单但功能强大的 Notes 应用程序?在本文中,我将引导您完成创建功能齐全的 Notes 应用程序的过程,该应用程序使用浏览器的本地存储功能在本地存储您的数据。 您将学习如何: 从头开始建立一个基本的 …

    2025年3月7日
    200
  • 使用 Nuxt v3 设置 Supabase Auth

    实现身份验证是您在大多数项目中都会做的事情,但由于您实际执行此操作的频率,您可能仍然不记得如何执行此操作。 以下是有关使用 nuxt v3 实施 supabase auth 的快速方法。在此示例中,我们将使用 otp,但它适用于所有情况。 …

    2025年3月7日
    200
  • HMPL – HTMX 的最佳替代品

    大家好!在本文中,我们将考虑像 hmpl 这样的 javascript 模块以及它如何在项目中替换 htmx。还要考虑它们的差异、优点和缺点。 当进一步比较这两个模块时,值得考虑的是,一个是模板语言,而另一个是一组用于处理 html 的工具…

    2025年3月7日
    200
  • 列表协调问题

    什么是调和(调和)? 在Web前端开发中,这是区分依赖列表的源和目标版本(创建可渲染元素列表)的过程告诉项目发生了什么:添加、删除或移动。 问题 前两个不是问题,但问题是判断一个项目是否移动了 如果跟踪项目的值为 [2, 1, 3] 列表中…

    2025年3月7日
    200
  • 如何使用 HTML 渲染器自动创建 PDF 文档

    自动化文档创建是许多 saas 产品的一项重要功能,无论是生成发票、报告还是证书。使用 html 渲染器,开发人员只需几行代码即可将动态 html 内容转换为高质量的 pdf 文档或 png 图像。在本指南中,我们将向您展示如何将 exoa…

    2025年3月7日
    200
  • 使用 React 构建租赁物业管理平台

    movin’ in 是一个面向代理的租赁物业管理平台,具有用于管理物业、客户和预订的后端、用于租赁物业的前端和移动应用程序。 通过以下解决方案,您可以通过将其托管在具有至少 1GB RAM 的 Docker Droplet 上,…

    2025年3月7日
    200

发表回复

登录后才能评论