专栏首页京程一灯JS和TS中的void[每日前端夜话0xBE]

JS和TS中的void[每日前端夜话0xBE]

预计阅读时间:5 分钟

作者:@ddprrt

翻译:疯狂的技术宅

来源:fettblog

如果你来自传统的强类型语言,可能会很熟悉 void 的概念:一种类型,告诉你函数和方法在调用时不返回任何内容。

void 作为运算符存在于 JavaScript 中,而作为基本类型存在于 TypeScript 中。在这两个世界中,void 的工作机制与大多数人习惯的有点不同。

JavaScript 中的 void

JavaScript 中的 void 是一个运算符,用于计算它旁边的表达式。无论评估哪个表达式,void总是返回undefined

let i = void 2; // i === undefined

我们为什么需要这样的东西?首先在早期,人们能够覆盖 undefined 并给它一个实际值。void 总是返回 real undefined。

其次,这是一种调用立即调用函数的好方法:

void function() {
  console.log('What')
}()

所有这些都没有污染全局命名空间:

void function aRecursion(i) {
  if(i > 0) {
    console.log(i--)
    aRecursion(i)
  }
}(3)

console.log(typeof aRecursion) // undefined

由于 void 总是返回 undefined,而 void 总是计算它旁边的表达式,你有一个非常简洁的方法从函数返回而不返回一个值,但仍然调用一个回调例如:

// returning something else than undefined would crash the app
function middleware(nextCallback) {
  if(conditionApplies()) {
    return void nextCallback();
  }
}

这让我想到了 void 最重要的通途:它是你程序的安全门。当你的函数总是应该返回 undefined 时,你可以确保始终如此。

button.onclick = () => void doSomething();

TypeScript 中的 void

TypeScript 中的 voidundefined 的子类型。JavaScript 中的函数总是返回一些东西。要么它是一个值,要么是 undefined

function iHaveNoReturnValue(i) {
  console.log(i)
} // returns undefined

因为没有返回值的函数总是返回 undefined,而 void 总是在 JavaScript 中返回 undefined,TypeScript 中的void 是一个正确的类型,告诉开发人员这个函数返回 undefined

declare function iHaveNoReturnValue(i: number): void

void 作为类型也可以用于参数和所有其他声明。唯一可以传递的值是 undefined

declare function iTakeNoParameters(x: void): void

iTakeNoParameters() // ?
iTakeNoParameters(undefined) // ?
iTakeNoParameters(void 2) // ?

所以 voidundefined 几乎是一样的。虽然有一点点不同,但这种差别很大:作为返回类型的 void 可以用不同的类型替换,以允许高级回调模式:

function doSomething(callback: () => void) {
  let c = callback() // at this position, callback always returns undefined
  //c is also of type undefiend
}

// this function returns a number
function aNumberCallback(): number {
  return 2;
}

// works ? type safety is ensured in doSometing
doSomething(aNumberCallback) 

这是期望的行为,通常用于 JavaScript 程序。你可以在我的其他文章中阅读更多关于这种被称为 substitutability 的模式。

如果你想确保传递只返回 undefined 的函数(如“nothing”),请确保调整你的回调方法签名:

- function doSomething(callback: () => void) {
+ function doSomething(callback: () => undefined) { /* ... */ }

function aNumberCallback(): number { return 2; }

// ? types don't match
doSomething(aNumberCallback) 

大概大部分时间你都能和 void 很好的相处。 原文:https://fettblog.eu/void-in-javascript-and-typescript/

往期精选
  • BootstrapVue 入门
  • JavaScript的工作原理:引擎、运行时和调用堆栈
  • 用 TypeScript 开发 Node.js 程序
  • 快速上手最新的 Vue CLI 3
  • JavaScript 程序员可以从C ++中学到些什么
  • 在同一基准下对前端框架进行比较
  • Edge 拥抱 Chromium 对前端工程师意味着什么?
  • 使你的 JavaScript 代码简单易读
  • Node.js多线程完全指南
  • deno如何偿还Node.js的十大技术债
  • 实战!半小时写一个脑力小游戏
  • CSS Flexbox 可视化手册
  • 世界顶级公司的前端面试都问些什么
  • V8引擎内部机制及优化代码的5个技巧

本文分享自微信公众号 - 前端先锋(jingchengyideng),作者:疯狂的技术宅

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-09-11

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 令人惊叹的JavaScript装B黑科技

    Javascript是一门很吊的语言,我可能学了假的JavaScript,哈哈,大家还有什么推荐的,补充送那啥邀请码。

    疯狂的技术宅
  • 前端要知道的Linux 的 RPM 和 YUM 包管理[每日前端夜话0x5D]

    许多 Linux 程序以源代码形式发行,用户可将它连同所需的手册页、配置文件等一起构建到需要的程序或程序集中。现在,大部分 Linux 发行商都使用预先构建的程...

    疯狂的技术宅
  • 使用ES6默认参数与属性简写编写更简洁的代码

    编写一个方法同样意味着开发一个API。不论是给你自己,你团队中的其他程序员还是其他使用你项目的开发者来说都是一样。根据你编写函数的大小,复杂程度以及目的,你需要...

    疯狂的技术宅
  • Linux使用命令修改默认启动为图形或字符界面

     因为要在Linux系统上装NVIDIA显卡驱动,默认重启必须是字符界面,因此把这块所需命令记录下来。

    Zoctopus
  • Qt编写自定义控件43-自绘电池

    到了9102年了,现在智能手机不要太流行,满大街都是,甚至连爷爷奶奶级别的人都会用智能手机,本次要写的控件就是智能手机中的电池电量表示控件,采用纯painter...

    feiyangqingyun
  • Qt编写自定义控件14-环形进度条

    环形进度条,用来展示当前进度,为了满足大屏UI的需要特意定制,以前有个叫圆环进度条,不能满足项目需要,只能重新定做,以前的进度间距不能自适应分辨率,而且当前进度...

    feiyangqingyun
  • Qt编写自定义控件15-百分比仪表盘

    百分比仪表盘,主要的应用场景是展示销售完成率、产品合格率等,也可以作为一个进度百分比展示,可以独立设置对应的标题文字,标题文字的颜色和整体的颜色都可以单独设置,...

    feiyangqingyun
  • OWASP物联网安全2018 TOP 10

    原文:https://www.owasp.org/index.php/OWASP_Internet_of_Things_Project

    苦叶子
  • <dubbo:annotation >配置 —— 分库遇到问题(2)

    在上篇笔记《context:component-scan 配置 —— 分库遇到问题(1)》中解决了 spring中某些实例被初始化了两次的问题, 但是紧接着又来...

    日薪月亿
  • 搭建一个MVP框架

      MVP是一种设计模式,是MVC模式的一种演变。他出现的主要目的是划分代码模块职责,降低模块耦合度,易于单元测试。

    饮水思源为名

扫码关注云+社区

领取腾讯云代金券