JavaScript中for-in遍历方式浅析
2014-02-10 16:50
169 查看
摘要:for-in遍历方式的循环计数器是字符串类型,遍历对象时为对象属性/方法名,遍历数组时为数组元素下标索引,与普通的for循环不同,for-in会将继承的属性/方法列出,这一点在使用时需要特别关注。
除了传统的for循环,JavaScript为遍历操作定义了for-in方式,根据数据源的不同,在使用时存在差异。
(1)遍历对象:
var fish = {
head : 1,
tail : 1,
}
for(var prop in fish) {
console.log(fish[prop]);
}
调试时观察:prop依次为'head','tail',即遍历对象属性时是以字符串类型存在的,循环计数器为对象的属性名。
(2)遍历数组
var arr = ['one', 'two', 'three'];
for(var prop in arr) {
console.log(prop);
}
调试时观察:prop依次为'0','1',即遍历数组时仍是以字符串类型存在,不同的是循环计数器为数组元素的下标。(这时可以试试用for循环输出,结果与for-in是一致的)
如果代码中加入:
if(Object.prototype.clone === 'undefined')
Object.prototype.clone = function() {};
则输出结果为:0,1,clone
如果这时用for循环输出,则仍为0,1;也就是说for-in循环会将当前操作的数据源所属类型具有的属性遍历出来(同样对对象fish用for-in时,也会输出clone),所以就要求在使用for-in遍历时拉着一根弦:如果仅对对象自有属性操作,需要将继承来的属性加以剔除,比如用hasOwnProperty()方法。
除了传统的for循环,JavaScript为遍历操作定义了for-in方式,根据数据源的不同,在使用时存在差异。
(1)遍历对象:
var fish = {
head : 1,
tail : 1,
}
for(var prop in fish) {
console.log(fish[prop]);
}
调试时观察:prop依次为'head','tail',即遍历对象属性时是以字符串类型存在的,循环计数器为对象的属性名。
(2)遍历数组
var arr = ['one', 'two', 'three'];
for(var prop in arr) {
console.log(prop);
}
调试时观察:prop依次为'0','1',即遍历数组时仍是以字符串类型存在,不同的是循环计数器为数组元素的下标。(这时可以试试用for循环输出,结果与for-in是一致的)
如果代码中加入:
if(Object.prototype.clone === 'undefined')
Object.prototype.clone = function() {};
则输出结果为:0,1,clone
如果这时用for循环输出,则仍为0,1;也就是说for-in循环会将当前操作的数据源所属类型具有的属性遍历出来(同样对对象fish用for-in时,也会输出clone),所以就要求在使用for-in遍历时拉着一根弦:如果仅对对象自有属性操作,需要将继承来的属性加以剔除,比如用hasOwnProperty()方法。
相关文章推荐
- JavaScript中for-in遍历方式示例介绍
- JavaScript中for-in遍历方式示例介绍
- Javascript研究: 遍历对象的方式Object.getOwnPropertyNames vs Object.keys vs for ...in
- Vue指令v-for之遍历输出JavaScript数组,json对象的几种方式
- JavaScript-//FOR/IN循环。当使用for/in循环遍历关联数组时,就可以清晰地体会到for/in的强大之处。
- JavaScript for in 遍历数组 【每日一段代码89】
- JS数组的遍历方式for循环与for...in
- javascript中的遍历for in 以及with的用法
- javaScript JSON 遍历(for in)
- Effective JavaScript Item 49 对于数组遍历,优先使用for循环,而不是for..in循环
- javascript for/in 循环遍历对象属性
- 【javascript】javascript中for...in...遍历关联数组
- javascript for-in有序遍历json数据并探讨各个浏览器差异
- Effective JavaScript Item 49 对于数组遍历,优先使用for循环,而不是for..in循环
- javascript中的遍历for in 以及with的用法
- javascript创建对象以及使用for(.. in ..)遍历对象的属性!
- JS数组的遍历方式for循环与for...in
- JS数组的遍历方式for循环与for...in
- Checking for Undefined, Null, and Empty Variables in JavaScript
- JavaScript for...in 循环的陷阱