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
      • 对于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,神奇吧!

    • 2
      点赞
    • 1
      收藏
      觉得还不错? 一键收藏
    • 1
      评论
    评论 1
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值