javascript数组遍历for与for in区别详解


Posted in Javascript onDecember 04, 2014

js中遍历数组的有两种方式

var array=['a']

//标准的for循环

for(var i=1;i<array.length;i++){

    alert(array[i])

}

//foreach循环

for(var i in array){

    alert(array[i])

}

正常情况下上面两种遍历数组的方式结果一样。首先说两者的第一个区别

标准的for循环中的i是number类型,表示的是数组的下标,但是foreach循环中的i表示的是数组的key是string类型,因为js中一切皆为对象。自己试试 alert(typeof i);这个区别是小问题。现在我加上如下代码,上面的执行结果就不一样了。

//扩展了js原生的Array

Array.prototype.test=function()

 

}

试试看上面的代码执行什么。我们发现标准的for循环任然真正的对数组循环, 但是此时foreach循环对我刚才写的test方法写打印出来了。这就是for与foreach遍历数组的最大区别,如果我们在项目采用的是用foreach遍历数组,假设有一天谁不小心自己为了扩展js原生的Array类,或者引入一个外部的js框架也扩展了原生Array。那问题就来了。

再此建议两点

1.不要用for in遍历数组,全部统一采用标准的for循环变量数组(我们无法保证我们引入的js是否会采用prototype扩展原生的Array)
2.如果要对js的原生类扩展的时候,不要采用prototype了

Javascript 相关文章推荐
window.parent与window.openner区别介绍
Apr 12 Javascript
页面刷新时记住滚动条的位置jquery代码
Jun 17 Javascript
常用jQuery选择器总结
Jul 11 Javascript
JavaScript页面模板库handlebars的简单用法
Mar 02 Javascript
深入理解JQuery循环绑定事件
Jun 02 Javascript
JS用斜率判断鼠标进入DIV四个方向的方法
Nov 07 Javascript
javascript checkbox/radio onchange不能兼容ie8处理办法
Jun 13 Javascript
Angular实现预加载延迟模块的示例
Oct 12 Javascript
vue实现底部菜单功能
Jul 24 Javascript
JavaScript ES6中的简写语法总结与使用技巧
Dec 30 Javascript
AJAX在JQuery中的应用详解
Jan 30 jQuery
在 Vue 中编写 SVG 图标组件的方法
Feb 24 Javascript
c#+jquery实现获取radio和checkbox的值
Sep 12 #Javascript
express的中间件cookieParser详解
Dec 04 #Javascript
express的中间件bodyParser详解
Dec 04 #Javascript
express的中间件basicAuth详解
Dec 04 #Javascript
详解JS函数重载
Dec 04 #Javascript
如何让你的Lightbox支持滚轮缩放及Base64图片
Dec 04 #Javascript
javascript常用代码段搜集
Dec 04 #Javascript
You might like
php实现快速排序法函数代码
2012/08/27 PHP
屏蔽PHP默认设置中的Notice警告的方法
2016/05/20 PHP
Yii2针对指定url的生成及图片等的引入方法小结
2016/07/18 PHP
php中青蛙跳台阶的问题解决方法
2018/10/14 PHP
laravel Task Scheduling(任务调度)在windows下的使用详解
2019/10/22 PHP
json跟xml的对比分析
2008/06/10 Javascript
从零开始学习jQuery (十) jQueryUI常用功能实战
2011/02/23 Javascript
Jquery实现仿新浪微博获取文本框能输入的字数代码
2013/02/22 Javascript
本地图片预览(支持IE6/IE7/IE8/Firefox3)经验总结
2013/03/25 Javascript
nodejs中实现sleep功能实例
2015/03/24 NodeJs
JavaScript实现可拖拽的拖动层Div实例
2015/08/05 Javascript
javascript使用输出语句实现网页特效代码
2015/08/06 Javascript
jQuery+Ajax请求本地数据加载商品列表页并跳转详情页的实现方法
2017/07/12 jQuery
vue watch深度监听对象实现数据联动效果
2018/08/16 Javascript
Angular6 写一个简单的Select组件示例
2018/08/20 Javascript
如何为vuex实现带参数的 getter和state.commit
2019/01/04 Javascript
jQuery判断自定义属性data-val用法示例
2019/01/07 jQuery
Layui数据表格之单元格编辑方式
2019/10/26 Javascript
Vue Router 实现动态路由和常见问题及解决方法
2020/03/06 Javascript
Element Notification通知的实现示例
2020/07/27 Javascript
pandas Dataframe行列读取的实例
2018/06/08 Python
python中的常量和变量代码详解
2018/07/25 Python
详解Django模版中加载静态文件配置方法
2019/07/21 Python
python调用函数、类和文件操作简单实例总结
2019/11/29 Python
Python tensorflow实现mnist手写数字识别示例【非卷积与卷积实现】
2019/12/19 Python
python3+selenium获取页面加载的所有静态资源文件链接操作
2020/05/04 Python
Django --Xadmin 判断登录者身份实例
2020/07/03 Python
Sasa莎莎海外旗舰店:香港莎莎美妆平台
2018/03/21 全球购物
法国购买二手电子产品网站:Asgoodasnew
2020/03/27 全球购物
药物学专业学生的自我评价
2013/10/27 职场文书
《月球之谜》教学反思
2014/04/10 职场文书
个人工作主要事迹
2014/05/08 职场文书
小学生推普周国旗下讲话稿
2014/09/21 职场文书
2019最新版股权转让及委托持股协议书范本
2019/08/07 职场文书
分享python函数常见关键字
2022/04/26 Python
Python中的协程(Coroutine)操作模块(greenlet、gevent)
2022/05/30 Python