在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; };