Made isObjectLiteral to work correctly with custom objects with empty prototypes.

This commit is contained in:
Robert Katic 2009-11-12 12:50:40 +08:00 committed by John Resig
parent 1ce92e022d
commit 990d9ca1b0
2 changed files with 14 additions and 3 deletions

View File

@ -328,13 +328,20 @@ jQuery.extend({
return false; return false;
} }
// not own constructor property must be Object
if ( obj.constructor
&& !hasOwnProperty.call(obj, "constructor")
&& !hasOwnProperty.call(obj.constructor.prototype, "isPrototypeOf") ) {
return false;
}
//own properties are iterated firstly, //own properties are iterated firstly,
//so to speed up, we can test last one if it is own or not //so to speed up, we can test last one if it is own or not
var key; var key;
for ( key in obj ) {} for ( key in obj ) {}
return !key || hasOwnProperty.call( obj, key ); return key === undefined || hasOwnProperty.call( obj, key );
}, },
isEmptyObject: function( obj ) { isEmptyObject: function( obj ) {

View File

@ -553,10 +553,14 @@ test("jQuery.extend(Object, Object)", function() {
same( empty.foo, optionsWithDate.foo, "Dates copy correctly" ); same( empty.foo, optionsWithDate.foo, "Dates copy correctly" );
var myKlass = function() {}; var myKlass = function() {};
var optionsWithCustomObject = { foo: { date: new myKlass } };
empty = {};
jQuery.extend(true, empty, optionsWithCustomObject);
same( empty.foo, optionsWithCustomObject.foo, "Custom objects copy correctly (no methods)" );
// Makes the class a little more realistic // Makes the class a little more realistic
myKlass.prototype = { someMethod: function(){} }; myKlass.prototype = { someMethod: function(){} };
empty = {}; empty = {};
var optionsWithCustomObject = { foo: { date: new myKlass } };
jQuery.extend(true, empty, optionsWithCustomObject); jQuery.extend(true, empty, optionsWithCustomObject);
same( empty.foo, optionsWithCustomObject.foo, "Custom objects copy correctly" ); same( empty.foo, optionsWithCustomObject.foo, "Custom objects copy correctly" );