【Web前端问题】关于javascript中==的判断
0 == "" // true
上面这段代码是隐式转换导致的还是因为0等于false,""也等于false所以它们才相等,但我觉得隐式转换的可能性大,因为使用 === 号就不会出现这种问题。
我的疑问是这样的它是
0 == 0
还是
false == false
回答:
我给你讲清楚吧,隐式转换这里没人比我更熟悉了。
首先看ECMAScript规范对==转换的规则:
左边typeof 0是number类型
右边typeof ""是string类型
根据对应规则,满足低4条规则,此时会进行conparison x==ToNumber(y)此时0==ToNumber("")
再来看看ECMAScript对ToNumber()的对应规则:
接着往下面找:
看到没,最后ToNumber("")会转成+0
最后就成了0==+0,你说等不等?记住隐式转换最后都会变成两个数字的比较。
具体对应规则这张图可以描述:
当然这都是最简单的,楼主可以试一试这几个:
[]==![]++[[]][+[]]+[+[]]==10
console.log(([][[]]+[])[+!![]]+([]+{})[!+[]+!![]])
好了,上面弄不懂的话,可以看看我写的两篇文章,要花时间研究才能看得懂。
从 []==![] 为 true 来剖析 JavaScript 各种蛋疼的类型转换
从++[[]][+[]]+[+[]]==10?深入浅出弱类型JS的隐式转换
弄懂上面,这些可以拿去练习:
1.{}+{}2.{}+[]
3.[]+{}
4.{}+1
5.({}+1)
6.1+{}
7.[]+1
8.1+[]
9.1-[]
10.1-{}
11.1-!{}
12.1+!{}
13.1+"2"+"2"
14.1+ +"2"+"2"
15.1++"2"+"2"
16.[]==![]
17.[]===![]
回答:
0
等于false
也是隐式类型转换
的一种。
回答:
转换都是false。
!!0!!""
当然,具体的比较要看规则
回答:
0会隐式转换为false,严格模式下会报错,建议用===来比较
回答:
0 == "" // true
这语句相当于 0 == Number("")
对于数字、字符串、布尔类型这3种类型之间的比较都是先转换成数字再比较。
回答:
js关于“==”的比较是有规则的,符合你这里的情况具体来说就是:如果一个值是数字,另一个是字符串,先将字符串转换成数字,然后使用转换后的值进行比较。
所以等号右侧的空字符串“”会转换成数字0,左右就相当了。在js权威指南上有关于==比较转换规则的详细介绍
以上是 【Web前端问题】关于javascript中==的判断 的全部内容, 来源链接: utcz.com/a/138369.html