void 0是什么

场景

当我们在 ts 中使用可选链时,会发现,最后的编译代码可能如下所示

const a = {
  name: 'fnn',
  age: 18
};
const b = a?.age

// 编译后如下

const b = a === null || a === void 0 ? void 0 : a.age;
export {};

这是我们发现 a?.age 这个判断会生成 a === null || a === void 0

那么 void 0 是什么呢

MDN 给出的解释是,对给定的表达式进行求值,然后返回 undefined

如下代码全部都返回 undefined

void 1;
void console.log('expression evaluated');
void function iife() {
  console.log('iife is executed');
}();
void function test() {
  console.log('test function executed');
};

有什么作用

  • void 运算符通常只用于获取 undefined 的原始值,一般使用 void(0)(等同于 void 0)
  • 这个运算符允许在表达式执行完成时,然后返回 undefined 值。
  • ES5 之前 undefined 是可以被修改的,因此 undefined 的值可能是不准确的

JavaScript URI

当用户点击一个以 javascript: 开头的 URI 时,它会执行 URI 中的代码,然后用返回的值替换页面内容,除非返回的值是 undefinedvoid 运算符可用于返回 undefined

<a href="javascript:void(0);">
  这个链接点击之后不会做任何事情
</a>

<a href="javascript:void(document.body.style.backgroundColor='green');">
	点击这个链接会让页面背景变成绿色。
</a>

箭头函数使用

箭头函数标准中,允许在函数体不使用括号来直接返回值。如果右侧调用了一个原本没有返回值的函数,其返回值改变后,则会导致非预期的副作用。
当函数返回值不会被使用到的时候,应该使用 void 运算符,来确保 API 改变时,并不会改变箭头函数的行为。

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

这确保了当 doSomething 的返回值从 undefined 变为 true 的时候,不会改变代码的行为,因为 void 始终返回 undefined

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wflynn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值