这篇文章主要讲解了“javascript的++[[]][+[]]+[+[]] = 10问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript的++[[]][+[]]+[+[]] = 10问题怎么解决”吧!
这是一个Javascript 语言题目,一个完全有效的等式,不信自己可以试一下,下面看看高人的题解:
++[[]][+[]]+[+[]]
如果把这段表达式拆分开来,它相等于:
++[[]][+[]]+[+[]]
在 JavaScript 里,+[] === 0 是完全正确的。 + 会把一些字符转化成数字,在这里,这个式子会变成 +""或 0。
因此,我们可以简化一下(++ 比 + 有更高的优先级):
++[[]][0]+[0]
因为 [[]][0] 的意思是:获取 [[]] 的第一个元素,这就得出了下面的结果:
[[]][0] 返回内部数组 ([])。根据语言规范,我们说 [[]][0] === [] 是不正确的,但让我们把这个内部数组称作 A,以避免错误的写法。
++[[]][0] == A + 1, 因为 ++ 的意思是”加一”。
++[[]][0] === +(A + 1);换句话说,你得到的永远是个数值( +1 并不一定得到的是个数值,但 ++一定是)。
同样,我们可以把这一堆代码简化的更清晰。让我们把 A 换回成 [] :
+([] + 1)+[0]
在 JavaScript 里,这也是正确的:[] + 1 === "1",因为 [] == "" (这相当于一个空的数组的内部元素连接),于是:
+([] + 1) === +("” + 1),并且 +("” + 1) === +("1"),并且 +("1") === 1
让我们再次简化一下:
1+[0]
同样,在 Javascript 里,这是正确的:[0] == "0",因为这是相当于一个有一个元素的数组的内部元素的连接。 各元素会使用,分隔。 当只有一个元素时,你可以推论出这个过程的结果就是它自身的第一个元素。
所以,最终我们得到 (数字 + 字符串 = 字符串):
1+"0"=== "10" // 耶!
感谢各位的阅读,以上就是“javascript的++[[]][+[]]+[+[]] = 10问题怎么解决”的内容了,经过本文的学习后,相信大家对javascript的++[[]][+[]]+[+[]] = 10问题怎么解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。