详谈js中标准for循环与foreach(for in)的区别


Posted in Javascript onNovember 02, 2017

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。那问题就来了。再此建议两点

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

如果要对js的原生类扩展的时候,不要采用prototype了

以上这篇详谈js中标准for循环与foreach(for in)的区别就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于Jquery的仿Windows Aero弹出窗(漂亮的关闭按钮)
Sep 28 Javascript
js捕获鼠标右键菜单中的粘帖事件实现代码
Apr 01 Javascript
如何解决Jquery库及其他库之间的$命名冲突
Sep 15 Javascript
JavaScript中对象介绍
Dec 31 Javascript
javascript解决IE6下hover问题的方法
Jul 28 Javascript
原生js实现addClass,removeClass,hasClass方法
Apr 27 Javascript
jQuery实现调整表格单列顺序完整实例
Jun 20 Javascript
js 博客内容进度插件详解
Feb 19 Javascript
jQuery插件FusionCharts绘制ScrollColumn2D图效果示例【附demo源码下载】
Mar 22 jQuery
vue对storejs获取的数据进行处理时遇到的几种问题小结
Mar 20 Javascript
深入理解js 中async 函数的含义和用法
May 13 Javascript
详解VSCode配置启动Vue项目
May 14 Javascript
使用 Node.js 模拟滑动拼图验证码操作的示例代码
Nov 02 #Javascript
基于JavaScript+HTML5 实现打地鼠小游戏逻辑流程图文详解(附完整代码)
Nov 02 #Javascript
vue-resource + json-server模拟数据的方法
Nov 02 #Javascript
详解vue-cli项目中用json-sever搭建mock服务器
Nov 02 #Javascript
Vue-cli 使用json server在本地模拟请求数据的示例代码
Nov 02 #Javascript
vue项目中使用axios上传图片等文件操作
Nov 02 #Javascript
JavaScript登录验证基础教程
Nov 01 #Javascript
You might like
php快速查找数据库中恶意代码的方法
2015/04/01 PHP
如何把php5.3版本升级到php5.4或者php5.5
2015/07/31 PHP
PHP请求Socket接口测试实例
2016/08/12 PHP
laravel实现Auth认证,登录、注册后的页面回跳方法
2019/09/30 PHP
学习jquery之一
2007/04/27 Javascript
Jquery动态进行图片缩略的原理及实现
2013/08/13 Javascript
JS动态修改iframe内嵌网页地址的方法
2015/04/01 Javascript
JavaScript实现自动对页面上敏感词进行屏蔽的方法
2015/07/27 Javascript
Javascript将数值转换为金额格式(分隔千分位和自动增加小数点)
2016/06/22 Javascript
js编写一个简单的产品放大效果代码
2016/06/27 Javascript
JavaScript中三个等号和两个等号的区别(== 和 ===)浅析
2016/09/22 Javascript
实例解析Array和String方法
2016/12/14 Javascript
JS 在数组指定位置插入/删除数据的方法
2017/01/12 Javascript
jQuery加密密码到cookie的实现代码
2017/04/18 jQuery
vue封装第三方插件并发布到npm的方法
2017/09/25 Javascript
浅谈如何使用 webpack 优化资源
2017/10/20 Javascript
JavaScript的Object.defineProperty详解
2018/07/09 Javascript
对angular 实时更新模板视图的方法$apply详解
2018/10/09 Javascript
vue中datepicker的使用教程实例代码详解
2019/07/08 Javascript
Python深入学习之上下文管理器
2014/08/31 Python
Python和Perl绘制中国北京跑步地图的方法
2016/03/03 Python
基于python requests库中的代理实例讲解
2018/05/07 Python
python实现pdf转换成word/txt纯文本文件
2018/06/07 Python
简单瞅瞅Python vars()内置函数的实现
2019/09/27 Python
通信工程毕业生求职信
2013/11/16 职场文书
音乐教学反思
2014/02/02 职场文书
生产部岗位职责范文
2014/02/07 职场文书
个人近期表现材料
2014/02/11 职场文书
党员干部承诺书
2014/03/25 职场文书
《红军不怕远征难》教学反思
2014/04/14 职场文书
公司副总经理岗位职责
2014/10/01 职场文书
2016年读书月活动总结范文
2016/04/06 职场文书
公证书
2019/04/17 职场文书
教您:房贷工资收入证明应该怎么写?
2019/08/19 职场文书
Python爬虫之爬取最新更新的小说网站
2021/05/06 Python
pytorch实现ResNet结构的实例代码
2021/05/17 Python