jQuery源码分析6: jQuery.isEmptyObject与jQuery.isPlainObject

jQuery源码分析6: jQuery.isEmptyObject与jQuery.isPlainObject

var hasOwn = Object.prototype.hasOwnProperty,

isEmptyObject: function( obj ) {
    for ( var name in obj ) {
        return false;
    }
    return true;
},

isPlainObject: function( obj ) {
    // 必须是一个Object,同时需要过滤掉DOM对象
    // Because of IE, we also have to check the presence of the constructor property.
    if ( !obj || jQuery.type(obj) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) {
        return false;
    }
 
    try {
        // 拥有自己的constructor属性必然不是Object
        if ( obj.constructor &&
            !hasOwn.call(obj, "constructor") &&
            !hasOwn.call(obj.constructor.prototype, "isPrototypeOf") ) {
            return false;
        }
    } catch ( e ) {
        // IE8,9 Will throw exceptions on certain host objects #9897
        return false;
    }
 
    // Own properties are enumerated firstly, so to speed up,
    // if last one is own, then all properties are own.
 
    var key;
    for ( key in obj ) {}
 
    return key === undefined || hasOwn.call( obj, key );
},

测试:
jQuery.isPlainObject({}); // true

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值