网站地图    收藏   

主页 > 前端 > javascript >

javascript中for in 中key的类型使用说明

来源:自学PHP网    时间:2014-09-19 14:47 作者: 阅读:

[导读] 本文章来给各位同学介绍javascript中for in 中key的类型使用说明,有需要了解学习的朋友可参考。...

javascript中循环的方式有很多while、for (var k = 0; k < 10; k++) {}、for in..,比如数组是arr[154, 256, 369, 852, 952]我想求这个数组的平均值,以前用for in用的比较少这次就尝试用了for in 循环,可总也算不对平均值,代码如下:

 代码如下 复制代码

function getAvgSum (arr, param, flag) {
 var as = 0;
 if (param) {
  for (var ai in arr) {
   as += parseInt(arr[ai][param]);
  }
 } else {
  for (var ai in arr) {
   //alert(typeof ai);
   as += parseInt(arr[ai]);
  }
 }

 if (flag == 'avg') {
  return as / (ai + 1);
  //return as / (parseInt(ai) + 1);
 }
 return parseInt(as);
}    

经过这种alert调试,终于找到了原因:alert(typeof ai)的结果是string,一直以为是数字。有同感的不


js 中for in 和for each in的区别


两个的作用都用来遍历对象,但为什么有了for in语句了还要for each in语句呢,后来看了下for each in开发的文档,for each in是作为E4X标准的一部分在javascript 1.6中发布的,而且它不是ECMAScript标准的一部分

 代码如下 复制代码
copytext
var 超毛 = {
    身高:"185CM",
    体重:"70公斤",
    年龄:40
};
for (var i in 超毛){
    document.write("i = " + i + "..................超毛[i] = " + 超毛[i] + "<br>");
}
/*
结果
i = 身高..................超毛[i] = 185CM
i = 体重..................超毛[i] = 70公斤
i = 年龄..................超毛[i] = 40
*/
for each (var i in 超毛){
    document.write("i = " + i + "..................超毛[i] = " + 超毛[i] + "<br>");
}
/*
结果
i = 185CM..................超毛[i] = undefined
i = 70公斤..................超毛[i] = undefined
i = 40..................超毛[i] = undefined
*/var 超毛 = {
    身高:"185CM",
    体重:"70公斤",
    年龄:40
};
for (var i in 超毛){
    document.write("i = " + i + "..................超毛[i] = " + 超毛[i] + "<br>");
}
/*
结果
i = 身高..................超毛[i] = 185CM
i = 体重..................超毛[i] = 70公斤
i = 年龄..................超毛[i] = 40
*/
for each (var i in 超毛){
    document.write("i = " + i + "..................超毛[i] = " + 超毛[i] + "<br>");
}
/*
结果
i = 185CM..................超毛[i] = undefined
i = 70公斤..................超毛[i] = undefined
i = 40..................超毛[i] = undefined

*/注意变量i的值是不一样的,for each in无法获得对象的属性名,只能获取到属性值

如果你想遍历对象,超毛建议还是使用for in
1,for in在遍历对象伤还是比for each in功能更加强大for in不仅能遍历处所有属性名和属性值,for each in只能遍历出属性值
2,for in是javascript 1.0就出来的语法,for each in是javascript 1.6才出来的语法,很多浏览器是 不u支持的,比如IE6,7,8是不支持的,所以还是推荐使用for in

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论