代码改变世界

为对象扩展原型方法要注意的坑

2018-07-27 16:43  盛世游侠  阅读(632)  评论(0编辑  收藏  举报

JavaScript里一切都是对象,这句话估计你已经听腻了。对象有个prototype属性可以用来动态扩展属性和方法,估计你也玩得如鱼得水了。

那么问题来了:

如果我想为任意类型的对象扩展一个getType方法,用来判断对象自身的类型到底是Boolean、Number、String、Array、Object,还是null、undefined,这个方法到底是写成下面这种独立的函数形式好呢?还是给对象的prototype扩展一个getType方法好呢?

    //判断对象的数据类型 ——  独立函数实现
    function getType(obj){
        var typeStr = Object.prototype.toString.call(obj).split(" ")[1];
        return typeStr.substr(0,typeStr.length-1);
    }

 

    //判断对象的数据类型 —— 原型扩展实现
    Object.prototype.getType = function(){
        var typeStr = Object.prototype.toString.call(this).split(" ")[1];
        return typeStr.substr(0,typeStr.length-1);
    }

 

看起来好像是原型扩展实现得好,直接obj.getType(),不要一个参数,多爽。

如果你决定使用原型扩展实现,那么恭喜你!你立刻就会遇到这个:

 

 

独立实现虽然调用的形式getType(obj)丑点,但是稳啊:

 

 所以做人要低调,还是不要装逼的好。