在Js中for in 是用來循環遍歷對象的屬性的,但是這個功能是有局限的,所遍歷的屬性必須是對象自定義的屬性,對象的內置屬性無法進行遍歷。
當在對象中自定義屬性覆蓋了內置屬性時:
IE6/7/8瀏覽器,for in仍不支持遍歷這些屬性。
chrome瀏覽器則可以對這些自定義的屬性進行遍歷。
var enumerablesTest = { toString: 1 };
var enumerables = true;
for (i in enumerablesTest) {
enumerables = null;
}
if( enumerables ){
enumerables = ['hasOwnProperty', 'valueOf', 'isPrototypeOf', 'propertyIsEnumerable',
'toLocaleString', 'toString', 'constructor'];
}
//--------------------------------------------------------------------------------------------------------------
Ext.apply = function(object, config, defaults) {
if (defaults) {
Ext.apply(object, defaults);
}
if (object && config && typeof config === 'object') {
var i, j, k;
for (i in config) {
object[i] = config[i];
}
if (enumerables) {
for (j = enumerables.length; j--;) {
k = enumerables[j];
if (config.hasOwnProperty(k)) {
object[k] = config[k];
}
}
}
}
return object;
};
