判断NaN

好久没有写js了,今天遇到一道数组去重的题目,在判断NaN的地方栽了跟头。题目要求NaN去重,空对象保留。
原数组:[false, true, undefined, null, NaN, 0, 1, {}, {}, ‘a’, ‘a’, NaN]
去重后:[false, true, undefined, null, NaN, 0, 1, {}, {}, ‘a’]
下面是我的源码:

Array.prototype.uniq = function () {
    var result = []
    var hasNaN = false

    for(var i = 0; i < this.length; i++ ){
        var elem = this[i]

        if(result.indexOf(elem) == -1){
            if(elem !== elem){
                if(!hasNaN){
                    result.push(elem)
                    hasNaN = true
                }
            }else{
                result.push(elem)
            }
        }
    }

    return result
}

1. 在indexOf判断中,NaN和空对象{}均返回-1,因此要判断NaN实现对其去重。

2.判断NaN的几种方法

在JavaScript中,有6个假值,分别为:false,0,null,“”,undefined,NaN。
其中前五个的判断都十分简单,直接使用严格相等“===”判断即可,但NaN的特殊性在于它不等于自身,So…

(1) isNaN()方法

我一开始就是使用的这个方法,得到的结果是这样:[false, true, undefined, null, 0, 1]
问题就在于这个函数总会隐式的将参数中的值转换成数字再做判断,这样就在判断很多明显不是NaN的值的时候也返回了true,比如:

isNaN

有一个方法提出在使用isNaN()函数前判断其是不是数值类型,以此来避免隐式转换,即
typeof(a) === 'number' && isNaN(a)
但这样稍显狭隘,因此我们可以使用后面讨论的第二种方法。

(2)严格不等!==

由于NaN不等于自身,使用严格相等时总是返回false,无法使用诸如
a === NaN
这样的代码进行条件判断,但换个角度想,正是由于它是唯一一个有此特性的值,因此我们可以使用严格不等来判断:
a !== a
一旦以上条件判断为真,那么a一定是NaN。搞定<(▰˘◡˘▰)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值