日期:2014-05-16  浏览次数:20378 次

javascript的==和===,以及if(xxx)总结

转载请注明 本文出自:http://blog.csdn.net/nancle

首先说==和===

  • 首先说明一个很特殊的值NaN, typeof(Nav)得到'number',但是NaN不等于任何一个值(包括它本身),判断一个值是不是NaN只能使用isNaN
    NaN == NaN //得到 false
    NaN === NaN //得到false
    isNaN(NaN) //得到true
  • 然后===也比较简单:
    1. 等号两边类型和值都相等才返回true
      1 === 1 //得到 true
      1 === ‘1’//得到false
    2. 对于对象、数组、函数(三者均为对象Object的instance):只有等号两边引用了同一个对象,才返回true;引用不同对象,即使两个对象值相等也返回false。
      var a = {test:'test'};
      var b = {test:'test'};
      var c = a;
      a === b //得到false
      a === c  //得到true
    3. 对于undefined和null:只有两边同时为undefined或者同时为null时完全相等
      undefined === undefined //得到true
      null === null //得到true
      undefined === null //得到false
  • ==稍微复杂些:
    1.  如果等号两边的类型和值相等则返回true
    2. 如果等号两边类型相等,但是值不相等,则按以下规则比较:
      • 如果一个值是数字,另一个值是字符串,把字符串转换为数字,再用转换后的值进行比较。
        1 == '1' //得到true
      • 如果一个值为true,将它转化为1,再进行比较。如果一个值为false,把它转化为0,再进行比较。
        true == 1 //得到true
        0 == false// 得到true
      • 如果等号两边都是对象,那么必须引用同一个对象才返回true。如果一个值是对象,另一个值是数字或字符串,将对象转换成原始类型的值,再进行比较。可以使用对象的toString()方法或valueOf()方法把对象转化成原始类型的值。JavaScript核心语言的内部类通常先尝试valueOf()方法转换,再尝试toString()方法转换,但是对于Date类,则先执行toString()方法再执行valueOf()方法转换。不属于JavaScript核心语言的对象则可以采用JavaScript实现定义的方式把自身转换成原始数值。
        var  a = {test:'test'};
        var  b = {test:'test'};
        a.valueOf = function(){return 1};
        b.valueOf = function(){return 1};
        a == b // 返回false
        1 == a //返回true
    3. 对于undefined和null: 等号两边出现任意一个都返回true
      undefined == undefined //得到true
      null == null //得到true
      undefined == null //得到true

然后说明if(xxx):

if(xxx)其实很简单,它始终会把xxx的值转换成Boolean(即true或者false);  0,'0',[],null,undefined,NaN转换成Boolean类型都为false。


附:这里说一个很有用的技巧,在变量前面加两个!! 取反符号,可以把变量强制转换成Boolean类型,这样一来,!!NaN ===  !!null也得到true,神奇吧!