JavaScript中for-in遍历方式示例介绍

 更新时间:2014年02月11日 10:12:02   作者:  
for-in遍历方式的循环计数器是字符串类型,遍历对象时为对象属性/方法名,遍历数组时为数组元素下标索引,与普通的for循环不同,需要的朋友可以参考下
摘要: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()方法。

相关文章

  • JavaScript中yield实用简洁实现方式

    JavaScript中yield实用简洁实现方式

    原以为是一个蛮复杂的题目,想了许久没思路,当然要实现绝对能实现,但如果分析JavaScript脚本或是动态产生代码,都太复杂了。
    2010-06-06
  • javascript实现左右缓动动画函数

    javascript实现左右缓动动画函数

    这篇文章主要为大家详细介绍了javascript实现左右缓动动画函数,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • ionic 上拉菜单(ActionSheet)实例代码

    ionic 上拉菜单(ActionSheet)实例代码

    ionic js 上拉菜单(ActionSheet)通过往上弹出的框,来让用户选择选项;点击取消按钮或者点击空白的地方来让它消失。本文给大家分享实现代码,感兴趣的朋友一起看看吧
    2016-06-06
  • 前端实现各种类型文件保存的方案总结

    前端实现各种类型文件保存的方案总结

    在Web开发中,文件下载是常见的交互需求,本文将系统总结前端实现文件保存的三大核心场景(图片、文本、网页)及对应技术方案,帮助开发者根据具体需求选择最优解,需要的朋友可以参考下
    2025-04-04
  • javascript concat数组累加 示例

    javascript concat数组累加 示例

    javascript concat数组累加使用实例。
    2009-09-09
  • JavaScript JMap类定义与使用方法示例

    JavaScript JMap类定义与使用方法示例

    这篇文章主要介绍了JavaScript JMap类定义与使用方法,涉及javascript类的定义、内部变量、函数的定义及使用相关操作技巧,需要的朋友可以参考下
    2019-01-01
  • 浅析JavaScript 函数防抖和节流

    浅析JavaScript 函数防抖和节流

    这篇文章主要介绍了JavaScript 函数防抖和节流的相关资料,文中讲解非常细致,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • 浅谈FastClick 填坑及源码解析

    浅谈FastClick 填坑及源码解析

    这篇文章主要介绍了浅谈FastClick 填坑及源码解析,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • JavaScript 上万关键字瞬间匹配实现代码

    JavaScript 上万关键字瞬间匹配实现代码

    发一篇之前写的文章,平时还是经常用到的,尤其是河蟹词特别多的聊天系统里
    2013-07-07
  • JavaScript多态与封装实例分析

    JavaScript多态与封装实例分析

    这篇文章主要介绍了JavaScript多态与封装,结合实例形式分析了JavaScript多态与封装的概念、功能、优缺点以及相关问题与注意事项,需要的朋友可以参考下
    2018-07-07

最新评论