javascript 使用for循环时该注意的问题-附问题总结


Posted in Javascript onAugust 19, 2015

如果您希望一遍又一遍地运行相同的代码,并且每次的值都不同,那么使用循环是很方便的。

很多时候我们都用到for循环,而用到for循环部门往往对一个数组进行循环,其中我们很多时候都是这样写的:

// 次佳的循环
for (var i = 0; i < myarray.length; i++) {
 // 使用myarray[i]做点什么
}

这样的代码虽然没有什么大问题,但是每次循环都会获取一下数组的长度,这回降低你的代码,尤其当myarray不是数组,而是一个HTMLCollection对象的时候。

再看看下面的这个代码:

for (var i = 0, max = myarray.length; i < max; i++) {
 // 使用myarray[i]做点什么
}

这样地代码只会获取一次数组的长度,提高了代码的质量;

伴随着单var形式,你可以把变量从循环中提出来,就像下面这样:

function looper() {
 var i = 0,
  max,
  myarray = [];
 // ...
 for (i = 0, max = myarray.length; i < max; i++) {
  // 使用myarray[i]做点什么
 }
}

javascript使用for循环时问题总结

这个问题的讨论最初来自公司内部邮件,我只是把这个问题的讨论内容记录下来。

有一些项目组在定位问题的时候发现,在使用“for(x in array)”这样的写法的时候,在IE浏览器下,x出现了非预期的值。

具体说,如果自定义了Array.prototype.indexOf方法(譬如源于某prototype污染),也许是因为老版本IE浏览器并不支持array.indexOf方法,而开发者又很想用,那么这样的浏览器可能会出现这样的问题:

Array.prototype.indexOf = function(){...};
var arr = [1, 2];
for (x in arr) console.log(x);

//会输出

1
2
function(){…}

换句话说,把indexOf这个方法给输出出来了。

解决方法很简单,要么别添加这个方法,要么用“for (i=0; i < array.length; i++)”这样的循环等等。

但是问题的本质呢?有人猜测,可能是因为for(x in obj)这种用法其实是去遍历一个对象,而array的实现其实也和普通的object一致,只不过key是既定的数值而已:

{0:"something", 1:"something else"}

在一则stackoverflow的问答里面也提到了,遍历数组的时候用for…in和for(;;)的区别,前者的含义是枚举对象的属性,存在这样两个问题:

枚举的顺序无法被保证;

继承属性也被枚举出来;

在对Array.prototype.forEach的支持上,从这张表中也可以明确看到,IE8及以下版本是无法准确支持的:

 javascript 使用for循环时该注意的问题-附问题总结

这里还有对forEach方法兼容性的详细阐述。事实上,主要的JavaScript框架(比如jQuery、Underscore和Prototype等等)都有安全和通用的for-each功能实现。

在JSLint的for in章节里面也提到,for in语句允许循环遍历对象的属性名,但是也会遍历到那些通过原型链继承下来的属性,这在很多情况下都会造成预期以外的错误。有一种粗暴的解决办法:

for (name in object)

 { if (object.hasOwnProperty(name))

 { .... } }

还有人提到了使用for(var i=0;i<length;i++)类似这样的循环时的问题,因为JavaScript没有代码块级别的变量,所以这里的i的访问权限其实是所在的方法。有的书上会建议程序员把这样的变量声明放到一处去,但是从直观性上说,在大部分情况下都不够合理。

使用JavaScript 1.7中引入的“let”可以解决这个问题,使i成为真正的代码块级别的变量:

for(let i =0; i < a.length; i++)

最后,在Google的JavaScript风格导引里面,也涉及到了这个约束:

for-in loop:


Only for iterating over keys in an object/map/hash

以上就是本文关于javascript 使用for循环时该注意的问题-附问题总结的全部内容,希望对今后的工作学习有所帮助,同时欢迎各位业内人士提出批评建议。

更多的可以查看这篇文章:https://3water.com/article/80351.htm

Javascript 相关文章推荐
关于跨站脚本攻击问题
Dec 22 Javascript
javascript面向对象包装类Class封装类库剖析
Jan 24 Javascript
jquery 多行文本框(textarea)高度变化
Jul 03 Javascript
使用Js让Html中特殊字符不被转义
Nov 05 Javascript
jquery获取当前点击对象的value方法
Feb 28 Javascript
jquery 页眉单行信息滚动显示实现思路及代码
Jun 26 Javascript
bootstrap-treeview自定义双击事件实现方法
Jan 09 Javascript
jQuery实现的自动加载页面功能示例
Sep 04 Javascript
JavaScript如何实现图片懒加载(lazyload) 提高用户体验(增强版)
Nov 30 Javascript
12个非常有用的JavaScript技巧
May 17 Javascript
BootStrap的双日历时间控件使用
Jul 25 Javascript
js+css实现红包雨效果
Jul 12 Javascript
jQuery满意度星级评价插件特效代码分享
Aug 19 #Javascript
easyui Draggable组件实现拖动效果
Aug 19 #Javascript
使用CamanJS在Web页面上处理图像的技巧
Aug 18 #Javascript
JS实现下拉菜单赋值到文本框的方法
Aug 18 #Javascript
JS实现可调整倒计时间代码分享
Aug 18 #Javascript
DOM事件阶段以及事件捕获与事件冒泡先后执行顺序(图文详解)
Aug 18 #Javascript
js实现带有介绍的Select列表菜单实例
Aug 18 #Javascript
You might like
discuz authcode 经典php加密解密函数解析
2020/07/12 PHP
PHP数字金额转换成中文大写显示
2019/01/05 PHP
Flash+XML滚动新闻代码 无图片 附源码下载
2007/11/22 Javascript
CLASS_CONFUSION JS混淆 全源码
2007/12/12 Javascript
Jquery 插件学习实例1 插件制作说明与tableUI优化
2010/04/02 Javascript
jQuery ajax在GBK编码下表单提交终极解决方案(非二次编码方法)
2010/10/20 Javascript
javascript中创建对象的几种方法总结
2013/11/01 Javascript
JavaScript弹出新窗口并控制窗口移动到指定位置的方法
2015/04/06 Javascript
javascript实现的淘宝旅行通用日历组件用法实例
2015/08/03 Javascript
jquery图片滚动放大代码分享(1)
2015/08/25 Javascript
AngularJS入门教程之数据绑定用法示例
2016/11/01 Javascript
JS及JQuery对Html内容编码,Html转义
2017/02/17 Javascript
JS实现select选中option触发事件操作示例
2018/07/13 Javascript
JS使用Prim算法和Kruskal算法实现最小生成树
2019/01/17 Javascript
node 标准输入流和输出流代码实例
2019/09/19 Javascript
python实现将pvr格式转换成pvr.ccz的方法
2015/04/28 Python
Python实现的密码强度检测器示例
2017/08/23 Python
基于腾讯云服务器部署微信小程序后台服务(Python+Django)
2019/05/08 Python
如何利用Python模拟GitHub登录详解
2019/07/15 Python
python3.7+selenium模拟淘宝登录功能的实现
2020/05/26 Python
详解Pycharm第三方库的安装及使用方法
2020/12/29 Python
只要五步 就可以用HTML5/CSS3快速制作便签贴特效(图)
2012/06/04 HTML / CSS
HTML5给汉字加拼音收起展开组件的实现代码
2020/04/08 HTML / CSS
艺龙旅行网酒店预订:国内、港澳台酒店
2018/06/26 全球购物
平安建设实施方案
2014/03/19 职场文书
高中课程设置方案
2014/05/28 职场文书
关于读书的演讲稿600字
2014/08/27 职场文书
2014年国庆节演讲稿
2014/09/02 职场文书
实习证明格式范文
2014/10/14 职场文书
表扬通报怎么写
2015/01/16 职场文书
机关工会工作总结2015
2015/05/26 职场文书
元旦主持词开场白
2015/05/29 职场文书
2016春节放假通知范文
2015/08/18 职场文书
浅谈python数据类型及其操作
2021/05/25 Python
python中的装饰器该如何使用
2021/06/18 Python
Python实现打乒乓小游戏
2021/09/25 Python