有趣的代码: fixTypeof

本文深入探讨typeof操作符与Object.prototype.toString.call方法在JavaScript中用于判断对象类型的差异,通过具体代码实例,展示如何更准确地识别不同类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

typeof 可以匹配对象的类型,但是他的能力很弱,比如 typeof new String('123')会显示的object这是我们不想看到的结果很久以前JQ的作者通过Object.prototype.toString.call(name)这逆天的方法帮我们指明的道路.


    function fixTyoeof(obj){
        var retVal;
        //由于typeof null 也会是object我们这里去排除
        if(obj === null)
            return 'null';
        //Math我们也去排除
        if(obj === Math)
            return 'Math';
        retVal = typeof obj
        if(retVal === 'object'){
            switch(obj.constructor){
                case String:
                    return 'string';
                case Number:
                    return 'number';
                case Boolean:
                    return 'boolean';
                case Array:
                    return 'array';
                case Date:
                    return 'date';
                case RegExp:
                    return 'regExp';
            }
        }
        return retVal;
    }
function fixTyoeof(key){
    switch(Object.prototype.toString.call(key)){
        case '[object Array]'         : return 'Array';
        case '[object String]'         : return 'String';
        case '[object RegExp]'         : return 'RegExp';
        case '[object Number]'         : return 'Number';
        case '[object Function]'    : return 'Function';
        case '[object Boolean]'     : return 'Boolean';
        case '[object Math]'        : return 'Math';
        case '[object Date]'        : return 'Date';
        default :
            //由于 IE678 null undefined 会显示[object Object] 所以我们直接匹配
            switch(key){
                case null             : return 'Null';
                case undefined         : return 'Undefined';
                default             : return 'Object';
            }
    }
}

第一版是通过 constructor 去识别,第二版是通过逆天的Object.prototype.toString.call(name)方法

 

转载于:https://www.cnblogs.com/somesayss/p/3633197.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值