javascript 隐性类型转换步骤

Posted 淡烘糕

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript 隐性类型转换步骤相关的知识,希望对你有一定的参考价值。

这里说的隐性类型转换,是==引起的转换。

  1. 如果存在NaN,一律返回false
  2. 再看有没有布尔,有布尔就将布尔转换为数字
  3. 接着看有没有字符串, 有三种情况,对方是对象,对象使用toString进行转换;对方是数字,字符串转数字;对方是字符串,直接比较;其他返回false
  4. 如果是数字,对方是对象,对象取valueOf进行比较, 其他一律返回false
  5. 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 隐性类型转换步骤的主要内容,如果未能解决你的问题,请参考以下文章

javascript双等号引起的类型转换

HTML Bookmarklet模板:将任何JavaScript代码片段转换为Bookmarklet

在代码片段中包含类型转换

隐性改变display类型

隐性改变display类型

10个JavaScript代码片段,使你更加容易前端开发。