如何在JavaScript中将数值转换为Boolean

开发 前端
JavaScript中如何将数值转换为Boolean?这篇文章帮你搞定!往下看吧。

本文转载自公众号“读芯术”(ID:AI_Discovery)

JavaScript中如何将数值转换为Boolean?这篇文章帮你搞定!往下看吧~

[[321184]]

字符串

  1. conststring = 'string';!!string; // true 
  2. Boolean(string); // true 

数值

  1. constnumber = 100;!!number; // true 
  2. Boolean(number); // true 

虚值

在JavaScript中,有6个虚值。如果将其中任何一个字符串转换为Boolean,它将变为false 。

  1. false 
  2. undefined 
  3. null 
  4. NaN 
  5. "" (empty string) 

任何不为虚值的都会转换为true。

示例

虚值的应用:

  1. !!false;// false 
  2. !!undefined; // false 
  3. !!null; // false 
  4. !!NaN; // false 
  5. !!0; // false 
  6. !!''; // false 

虚值在Boolean上下文中的应用:

  1. Boolean(false);// false 
  2. Boolean(undefined); // false 
  3. Boolean(null); // false 
  4. Boolean(NaN); // false 
  5. Boolean(0); // false 
  6. Boolean(''); // false 

当心 ‘false’

  1. constvalue = 'false';!!value; // true 
  2. Boolean(value); // true 

注意“false”必须写在引号之间。虽然是虚值,但实际上是一个字符串。大多数人都不会在这里中圈套,但还是需要随时保持警惕。

如何在JavaScript中将数值转换为Boolean

图源:digilentin

如何操作该代码

首先! 将该值强制转换为Boolean并取反。在上下文中, !value将变回虚值。所以为了将value恢复成真值,将另一个“!” 放入操作中,因此这里出现了两个!。

  1. const value = 'string';!value; //false!!value; // true 

速度测试

boolean vs !!

看起来像 !! 但测试速度比Boolean快。

[[321186]]

图源:unsplash

有些人更喜欢Boolean,因为它更明确。但是,KyleSimpson在《你不知道的JavaScript》中提到,这两者都是明确的。

  1. //better (works explicitly): 
  2. if (!!a) { 
  3. }// also great (works explicitly): 
  4. if (Boolean(a)) { 

这里不会给你标准答案,你可以按需选择。笔者会在个人开发的项目中继续使用!!,其键入较少而且笔者对这种语法有了解。

反之,如果是作为团队考虑,笔者可能会选择Boolean。大多数开发人员都能更好地理解这一点。无论选择哪一个,最重要的是保持代码一致,不要换来换去,选择一种并坚持下去。

这更像是一种偏好选择,不要剥夺自己理解两种代码的权利。

避免newBoolean

使用基元而不是对象类型

  1. var str = 'str';// Avoid 
  2. typeof new Boolean(str); // object// Preferred 
  3. typeof Boolean(str); // boolean 
  4. typeof !!str; // boolean 

值得注意的是,new Boolean不是boolean,而是布尔值的示例。基元比较廉价,相比对象类型应优先使用。

new Boolean(str) 可以返回对象类型。Boolean(str)只返回boolean的原始值。笔者猜测Boolean(str)比!!str更快。因为这只是一项操作,但是浏览器也有可能实施优化,以便程序员看到 !! 他们知道直接将参数转换为boolean原始值(而不是实际执行NOT()连续两次)。

基元很便宜,它们是不可变的,因此可以共享引用,而不必在实例上保留任何状态。要么true要么false。

但newBoolean(str)是一个对象。它有自己的唯一存储地址,并且可以保存唯一的内部状态。这意味着它不能只保存对不可变单例实例的引用。每次运行new Boolean(str) 实例化都会产生一个全新的Boolean()对象。

使用Boolean构造函数删除空字符串

CJJ.:这是经典示例。如果得到一个用逗号分隔的字符串值列表,并且想要过滤掉空字符串,则可以将Boolean构造函数传递给Array.prototype.filter,它将自动去除零长度字符串,而仅保留一个有效的字符串数组。

  1. var str'some,list,,of,values'
  2. var arr = str.split(',');arr; // [ 'some', 'list', '', 'of', 'values']arr.filter(Boolean); // [ 'some', 'list', 'of', 'values' ] 

你学会了吗?

 

责任编辑:赵宁宁 来源: 读芯术
相关推荐

2022-12-25 16:15:38

HTMLJava可视化文档

2022-12-25 15:56:30

JavaScript字符串

2021-12-29 07:56:32

Go byte io.Reader

2016-11-15 14:29:14

Linux文件编码转换

2015-11-24 09:53:22

AngularJSXMLJSON

2022-09-22 11:40:11

JavaScript数组开发

2023-10-16 09:26:48

CSS类型转换

2024-09-18 08:00:05

C#编程

2021-10-29 15:13:21

LinuxPDF文件

2024-03-12 07:35:39

Python字符串列表

2009-12-01 14:00:37

PHP字符串转换为数值

2015-09-14 14:49:39

MySQLMariaDBLinux

2021-06-07 12:20:14

LinuxASCII命令

2022-05-31 10:38:50

Linux密码scp

2020-03-06 08:56:41

Linux运算符文本

2022-12-19 15:28:31

JavaScrip字符串

2021-08-26 09:46:22

JavaScript字符串URL

2014-05-04 12:51:21

Javascript编译器

2019-08-21 13:30:25

Node.jsSVG前端

2021-04-22 07:41:46

JavaScript类型转换
点赞
收藏

51CTO技术栈公众号