一篇文章搞定JavaScript类型转换(面试常见)
前端之家收集整理的这篇文章主要介绍了
一篇文章搞定JavaScript类型转换(面试常见),
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_4040@为啥要说这个东西?一道面试题就给我去说它的动机。
@H
404_0@题如下:
<div class="jb51code">
<pre class="brush:js;">
var bool = new Boolean(false);
if (bool) {
alert('true');
} else {
alert('false');
}
@H_
404_0@
运行结果是true!!!
@H_
404_0@其实啥类型转换啊,操作符优先级啊,这些东西都是最最基本的。犀牛书上有详细的介绍。但我很少去翻犀牛书的前5章。。。
@H_
404_0@比如说优先级那块儿,很多书都教育我们,“不用去背诵优先级顺序,不确定的话,加括号就行了。“平常我们写
代码时也确实这么做的。
@H_
404_0@但现实是啥呢?面试时会出这种题,让你来做。。。真不知道这种题的意义是啥。。。
@H_
404_0@抱怨到此为止,本文尝试来
解决类型转换问题,争取把《JS权威指南》49页那个表背下来。
@H_
404_0@
都有哪些东西是假值?
@H_
404_0@共6个:
@H_
404_0@上面的顺序是按照基本类型来排列的。
@H_
404_0@除此之外的一律不是!!哪怕是如下形式:
@H_
404_0@
if (a && b)的正确理解方式是
:a && b进行表达式求值后,然后再转换为Boolean类型。
@H_
404_0@&&是种短路语法,求值后不一定是个Boolean类型,更不是两边转化布尔值再运算。
@H_
404_0@比如 2&&3 的结果是3,不是true。
@H_
404_0@所以if(a && b),我们平常理解的那种,"如果a和b同时为真的话",是一种
错误的描述方式。
@H_
404_0@
其他基本类型转化为字符串
,基本和预期的一样:
@H_
404_0@
其他基本类型转化为数字
,需要特殊记忆:
@H_
404_0@其中null,空字符是0,undefined是NaN。
@H_
404_0@以上,基本类型转换都说明白了。
@H_
404_0@
下面来看看引用类型转换为基本类型。
@H_
404_0@
引用类型转换为布尔,始终为true
@H_
404_0@
引用类型转换为字符串
@H_
404_0@1.优先
调用toString
方法(如果有),看其返回结果是否是原始类型,如果是,转化为字符串,返回。
@H_
404_0@2.否则,
调用valueOf
方法(如果有),看其返回结果是否是原始类型,如果是,转化为字符串,返回。
@H_
404_0@3.其他报错。
@H_
404_0@
引用类型转化为数字
@H_
404_0@1.优先
调用valueOf
方法(如果有),看其返回结果是否是基本类型,如果是,转化为数字,返回。
@H_
404_0@2.否则,
调用toString
方法(如果有),看其返回结果是否是基本类型,如果是,转化为数字,返回。
@H_
404_0@3.其他报错。
@H_
404_0@首先我们看看常见引用类型toString和valueOf返回什么?
@H_
404_0@因此对应的转换为字符串和数字的情形是:
@H_
404_0@再来个报错的情形:
@H_
404_0@以上类型转换规律基本说完。
@H_
404_0@
最后来说一下万恶的“==”
@H_
404_0@面试题如下:
@H_
404_0@本以为会弹出true的。天那!为啥是false?
@H_
404_0@哈哈。。。
@H_
404_0@双等号,如果两边类型不同,会有隐式转换发生。犀牛书75页总结如下:
@H_
404_0@1,null和undefined,相等。
@H_
404_0@2,数字和字符串,转化为数字再比较。
@H_
404_0@3,如果有true或false,转换为1或0,再比较。
@H_
404_0@4,如果有引用类型,优先
调用valueOf。
@H_
404_0@5,其余都不相等。
@H_
404_0@因此有:
@H_
404_0@0 == false之所以为true根据第3条。
@H_
404_0@"" == false之所以为true根据第3条,变成了"" == 0,再根据第2条。
@H_
404_0@第4条再来一个例子:
@H_
404_0@其上结果为true,原因如下:
@H_
404_0@[[2]]的valueOf是对象本身,不是基本类型。
@H_
404_0@尝试
调用toString的结果是'2'。
@H_
404_0@因此变成了'2'和数字2的比较。根据第2条,相等。WTF!!
@H_
404_0@最后说句,使用"==="就没有这些问题了。
@H_
404_0@以上所述是小编给大家介绍的一篇
文章搞定JavaScript类型转换(面试常见)。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可
分享给好友!感谢
支持。
原文链接:https://www.f2er.com/js/42234.html