我是靠谱客的博主 机智康乃馨,最近开发中收集的这篇文章主要介绍JavaScript奇技淫巧之遍历数组,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

正常的for循环就不提了,直接进入正题。如下:

 

//示例1
for(var i=0,a;a=["jack","tom","lily","andy"][i++];){
console.log(a);
}
//示例2
var ary = ["jack","tom","lily","andy"];
for(var i=0,a;a=ary[i++];){
console.log(a);
}

 

从firebug控制台能看到依次输出jack ,tom ,lily ,andy。这里有个疑问,示例1不知是否会每次都产生一个数组对象实例,如果是,数组很大时可能会有性能问题?

 

这个技巧关键是这句

a = ary[i++];

 

js中数组实际上也是一个普通的Object。属于索引数组且并非“连续分配”内存的,因此索引方法并不会带来很高的效率。

 

见http://snandy.iteye.com/blog/276054

 

中括号[i++]依然是一个普通对象取属性操作而已,试试看

 

var ary = ["jack","tom","lily","andy"];
for(var a in ary) {
console.log(a);
}
 

firebug控制台输出0,1,2,3。证明了0,1,2,3的确是数组ary的属性。

 

既然是ary的属性,那么是否可以通过点运算符(.)来存取呢?试试看

 

for(var j=0;j<ary.length;j++) {
console.log(ary.j);//undefined
}
 

 

为什么示例1,2中用中括号[]存取就可以了呢?因为中括号ary[0],ary[1],ary[2],ary[3]里的0,1,2,3是字符串类型的。如下:

 

for(var atr in ary) {
console.log(atr + ":" + typeof atr);
}

 输出如下:

0:string
1:string
2:string
3:string

鲜为人知的便是:用中括号[]存取时,js引擎内部隐式的将数字转成了字符串。

见: http://snandy.iteye.com/blog/284805

 

 

 

 

 

 



最后

以上就是机智康乃馨为你收集整理的JavaScript奇技淫巧之遍历数组的全部内容,希望文章能够帮你解决JavaScript奇技淫巧之遍历数组所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部