Js for in對象屬性遍歷問題


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

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM