网站首页 > 技术文章 正文
全文共1396字,预计学习时长7分钟
JavaScript中如何将数值转换为Boolean?这篇文章帮你搞定!往下看吧~
字符串
conststring = 'string';!!string; // true
Boolean(string); // true
数值
constnumber = 100;!!number; // true
Boolean(number); // true
虚值
在JavaScript中,有6个虚值。如果将其中任何一个字符串转换为Boolean,它将变为false 。
false
undefined
null
NaN
0
"" (empty string)
任何不为虚值的都会转换为true。
示例
虚值的应用:
!!false;// false
!!undefined; // false
!!null; // false
!!NaN; // false
!!0; // false
!!''; // false
虚值在Boolean上下文中的应用:
Boolean(false);// false
Boolean(undefined); // false
Boolean(null); // false
Boolean(NaN); // false
Boolean(0); // false
Boolean(''); // false
当心 ‘false’
constvalue = 'false';!!value; // true
Boolean(value); // true
注意“false”必须写在引号之间。虽然是虚值,但实际上是一个字符串。大多数人都不会在这里中圈套,但还是需要随时保持警惕。
如何操作该代码
首先! 将该值强制转换为Boolean并取反。在上下文中, !value将变回虚值。所以为了将value恢复成真值,将另一个“!” 放入操作中,因此这里出现了两个!。
const value = 'string';!value; //false!!value; // true
速度测试
boolean vs !!
看起来像 !! 但测试速度比Boolean快。
有些人更喜欢Boolean,因为它更明确。但是,KyleSimpson在《你不知道的JavaScript》中提到,这两者都是明确的。
//better (works explicitly):
if (!!a) {
}// also great (works explicitly):
if (Boolean(a)) {
}
这里不会给你标准答案,你可以按需选择。笔者会在个人开发的项目中继续使用!!,其键入较少而且笔者对这种语法有了解。
反之,如果是作为团队考虑,笔者可能会选择Boolean。大多数开发人员都能更好地理解这一点。无论选择哪一个,最重要的是保持代码一致,不要换来换去,选择一种并坚持下去。
这更像是一种偏好选择,不要剥夺自己理解两种代码的权利。
避免newBoolean
使用基元而不是对象类型
var str = 'str';// Avoid
typeof new Boolean(str); // object// Preferred
typeof Boolean(str); // boolean
typeof !!str; // boolean
CJJ.:值得注意的是,new Boolean不是boolean,而是布尔值的示例。基元比较廉价,相比对象类型应优先使用。
CJJ.:new Boolean(str) 可以返回对象类型。Boolean(str)只返回boolean的原始值。笔者猜测Boolean(str)比!!str更快。因为这只是一项操作,但是浏览器也有可能实施优化,以便程序员看到 !! 他们知道直接将参数转换为boolean原始值(而不是实际执行NOT()连续两次)。
CJJ.:基元很便宜,它们是不可变的,因此可以共享引用,而不必在实例上保留任何状态。要么true要么false。
但newBoolean(str)是一个对象。它有自己的唯一存储地址,并且可以保存唯一的内部状态。这意味着它不能只保存对不可变单例实例的引用。每次运行new Boolean(str) 实例化都会产生一个全新的Boolean()对象。
特别致谢:CJJ
使用Boolean构造函数删除空字符串
CJJ.:这是经典示例。如果得到一个用逗号分隔的字符串值列表,并且想要过滤掉空字符串,则可以将Boolean构造函数传递给Array.prototype.filter,它将自动去除零长度字符串,而仅保留一个有效的字符串数组。
var str= 'some,list,,of,values';
var arr = str.split(',');arr; // [ 'some', 'list', '', 'of', 'values']arr.filter(Boolean); // [ 'some', 'list', 'of', 'values' ]
特别致谢:CJJ
你学会了吗?
留言点赞关注
我们一起分享AI学习与发展的干货
如转载,请后台留言,遵守转载规范
- 上一篇: JavaScript类型转换机制,你了解吗
- 下一篇: JS对象到原始值的转换(js对象初始化)
猜你喜欢
- 2024-11-01 Airbnb 开源力作:自动将 JavaScript 代码转换为 TypeScript
- 2024-11-01 JavaScript类型在什么情况下会发生类型自动转换
- 2024-11-01 js如何将接口get参数串转换成post格式输出
- 2024-11-01 【JS 字符转换】fromCharCode和charCodeAt
- 2024-11-01 几个JS开发小技巧,转换(js 开发)
- 2024-11-01 JavaScript将unicode编码转换为中文
- 2024-11-01 每日一题(js篇)通过js做进制转换(js 10进制转2进制)
- 2024-11-01 JavaScript-类型转换 224(javascript)
- 2024-11-01 基于Javascript编写的开源Markdown和HTML相互转换器——showdown
- 2024-11-01 一文读懂js中的隐式类型转换(js隐式调用)
- 1507℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 510℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 486℃MySQL service启动脚本浅析(r12笔记第59天)
- 466℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 464℃启用MySQL查询缓存(mysql8.0查询缓存)
- 444℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 423℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 420℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)