当前位置: 首页 > news >正文

猜猜 JavaScript 输出:(! + [] + [] + ![]).length

一起猜

最近看到一个很有意思的题,直接来看,下面这段代码的打印结果是什么?

console.log((! + [] + [] + ![]).length)

猜猜看,你的答案是什么,打在评论区。


我的答案是 undefined,正如我的英文名

image.png

为什么呢?因为我第一眼看到题目,只想到了 ![] 的结果是 false

而前面! + [] + []的逻辑没想明白,但是我估计得出的应该也是个布尔值

两个布尔值相加,最后还是个布尔值

布尔值取 length,应该是返回undefined

揭晓答案

但是在控制台运行后我人傻了,答案是 9 !!!

看到结果第一时间我还以为是全当字符串拼接起来了,但是一数,全拆开也是8个字符串啊。然后分析了下。

一步一步来看。

首先 + 加法操作符是从左到右计算的,所以不能自己想当然的给公式加上无形的“括号”。

所以应该一个值一个值来加。首先是! + []

! 是逻辑非操作符。可以用于 js 中的任何值,逻辑非操作符首先会将操作数转化为布尔值,然后在对其取反。

然后我又蒙住了,我知道 !值 的写法可以转 boolean,难道! + 值的写法也能隐式转换成布尔?

但是想不通其中的逻辑。

突然我幡然醒悟,应该把! + []拆解成 !+ [],把+[]当作值,那+ []是什么呢?

一元正号运算符位于其操作数前面,计算其操作数的数值,如果操作数不是一个数值,会尝试将其转换成一个数值。

任何值前面加上+加号操作符都会隐式转换成数值,如果解析失败,则转换结果为 NaN。

+'123'    //123
+'abin'   //NaN
+3        //3
+true     //1
+false    //0
+null     //0
+[]       //0
+undefined //NaN
+function(){} //NaN
+new Date()  //1695781396548  对应的毫秒数

这下是不是就能看通了,+ []的值为 0,

原式就相当于!0 + [] + ![] => true + [] + false

因为加法操作符如果两边都不是数字/字符串的时候会强制把操作值转换成字符串/数字,优先转换字符串,

所以true + [] + false => 'true' + [].toString() + false

现在题目就很简单了,

[].toString()的结果是空字符串,

所以'true' + [].toString() + false => 'true' + '' + false

最后得出结论

('true' + '' + false).length => 'truefalse'.length

答案是 9 !!!

你猜对了吗😜😜😜

说在最后

这种题目看着很怪,其实你只要不盲目的随意拆解题干,按照正常计算思路往下捋,就能捋出答案(马后炮🤪)

这道题的核心关键点有以下几点:

  • 加法运算符一定要从左到右看
  • !非运算符单独使用没有效果,所以会将 +[] 看作整体
  • +操作数 一元正号加上操作数会将操作数强制转换为数字
http://www.lryc.cn/news/184844.html

相关文章:

  • MTK Android12静默安装接口
  • 基于电容电流前馈与电网电压全前馈的三相LCL并网逆变器谐波抑制Simulink仿真
  • Python数据攻略-Pandas与统计数据分析
  • 【gcc】RtpTransportControllerSend学习笔记 1
  • 若依分离版-前端使用
  • 微信小程序-2
  • 卷积神经网络的发展历史-ResNet
  • 基于瞬时无功功率ip-iq的谐波信号检测Simulink仿真
  • node安装,nvm管理器
  • 华为云云耀云服务器L实例评测|Ubuntu云锁防火墙安装搭建使用
  • C# OpenCvSharp 实现迷宫解密
  • 趣味工具箱小程序源码
  • 互联网Java工程师面试题·Redis 篇·第二弹
  • FreeRTOS入门教程(信号量的概念及API函数使用)
  • 简易版Pycharm(2023)+Conda开发环境配置教程
  • 深入浅出,SpringBoot整合Quartz实现定时任务与Redis健康检测(二)
  • 小谈设计模式(22)—单例模式
  • 华为OD机考算法题:分班
  • 【gcc】RtpTransportControllerSend学习笔记 3:gcc
  • CSP-J第二轮试题-2019年-3题
  • 数据库:Hive转Presto(三)
  • 【AI视野·今日Robot 机器人论文速览 第四十八期】Thu, 5 Oct 2023
  • 学信息系统项目管理师第4版系列20_风险管理
  • 卷积神经网络的发展历史-VGG
  • qt解决信号和槽连接时传递额外参数的问题
  • 『力扣每日一题14』:消失的数字
  • 【b站韩顺平 快速学Java课】Java的JDK8(包括公共JRE8)安装教程 总结
  • Spark 弹性分布式数据集 RDD
  • 电脑被删除的文件怎么恢复?2023年数据恢复方法分享
  • 李宏毅 2022机器学习 HW3 boss baseline 上分记录