为什么 ('b'+'a'+ + 'a' + 'a').toLowerCase() 'banana' 的结果是?
当我的一个朋友偶然发现这段 JavaScript 代码时,我正在练习一些 JavaScript:
I was practicing some JavaScript when one of my friends came across this JavaScript code:
document.write(('b' + 'a' + + 'a' + 'a').toLowerCase());
以上代码回答"banana"
!谁能解释一下为什么?
The above code answers "banana"
!
Can anyone explain why?
推荐答案
+'a'
解析为 NaN
("Not a Number") 因为它强制转换为字符串为数字,而字符 a
不能被解析为数字.
+'a'
resolves to NaN
("Not a Number") because it coerces a string to a number, while the character a
cannot be parsed as a number.
document.write(+'a');
小写变成banana
.
"ba"
加上NaN
,由于类型转换,将NaN
变成字符串"NaN"
,给出 baNaN
.然后后面有一个a
,给出baNaNa
.
Adding NaN
to "ba"
turns NaN
into the string "NaN"
due to type conversion, gives baNaN
.
And then there is an a
behind, giving baNaNa
.
+ +
之间的空格是为了使第一个字符串连接和第二个一元加号(即正")运算符.如果你使用 'ba'+(+'a')+'a'
得到相同的结果,解析为 'ba'+NaN+'a'
,即由于类型杂耍,相当于 'ba'+'NaN'+'a'
.
The space between + +
is to make the first one string concatenation and the second one a unary plus (i.e. "positive") operator.
You have the same result if you use 'ba'+(+'a')+'a'
, resolved as 'ba'+NaN+'a'
, which is equivalent to 'ba'+'NaN'+'a'
due to type juggling.
document.write('ba'+(+'a')+'a');
相关文章