javascript 隐性类型转换步骤
Posted 淡烘糕
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript 隐性类型转换步骤相关的知识,希望对你有一定的参考价值。
这里说的隐性类型转换,是==引起的转换。
- 如果存在NaN,一律返回false
- 再看有没有布尔,有布尔就将布尔转换为数字
- 接着看有没有字符串, 有三种情况,对方是对象,对象使用toString进行转换;对方是数字,字符串转数字;对方是字符串,直接比较;其他返回false
- 如果是数字,对方是对象,对象取valueOf进行比较, 其他一律返回false
- null, undefined不会进行类型转换, 但它们俩相等
这个顺序一定要死记。
下面是一些例子,自己跑一下:
0 == undefined //false 1 == true //true 2 == {valueOf: function(){return 2}} //true NaN == NaN //false 8 == undefined //false 1 == undefined //false null == {toString: function(){return 2}} //false 0 == null //false null == 1 //false { toString:function(){ return 1 } , valueOf:function(){ return [] }} == 1
以上是关于javascript 隐性类型转换步骤的主要内容,如果未能解决你的问题,请参考以下文章