prototype与expando属性的遍历

 JS的对象(不仅是Object)能够像html元素对象同样,添加任意的自定义属性值。也就是说JS的对象,天生都是Key/Value ,在遍历属性时,expando导入属性和prototype导入属性存在了混淆。html

 

js的prototype特性对对象的扩充很是的方便,因此咱们在制做一些jst类库的时候,通常都会使用prototype特性为对象添加方法,好比咱们对Object进行以下prototype扩充:ide

Object.prototype.GetValue=function(){}spa

Object.prototype.Method=function(){}prototype

Object.prototype.QequestData=function(){}htm

这个时候若是再使用Object做为items结构来使用,咱们就会遇到遍历这个items的错误,看下面的代码:对象

var objItems = {};blog

objItems["1"] = "1111";get

objItems["2"] = "2222";it

objItems["3"] = "3333";io

遍历这个集合:

function DisplayItems(obj) {

var values = [];

for (var key in obj) {

values.push(obj[key]);

}

return values;

};

获取值以下图:

因为prototype属性的优先级很高,在对象实例生成的时候就expand到对象实例中去了。因此咱们创建的任何一个对象,都会包含相同的prototype属性。这样一来就好办了,咱们把objItems中的prototype属性找出来过滤掉就好了呗。参考代码以下

function GetExpandAttr(items) {

var values = [];

var obj = new items.constructor();

for (var key in items) {

if (obj[key] != items[key]) {

values.push(items[key]);

}

}

return values;

};

遍历结果以下图:

 

$(document).ready(function () {

$("#btn1").click(function () {

alert(DisplayItems(objItems));

});

$("#btn2").click(function () {

alert(GetExpandAttr(objItems));

});

});

相关文章
相关标签/搜索