JavaScript中遍历数组和对象的方法

js数组遍历和对象遍历

针对js各种遍历作一个总结分析,从类型用处,分析数组和对象各种遍历使用场景,优缺点等

JS数组遍历:

1,普通for循环,经常用的数组遍历

var arr = [1,2,0,3,9,10,20,30];
 for ( var i = 0; i <arr.length; i++){
    console.log(arr[i]);
}

2,优化版for循环:使用变量,将长度缓存起来,避免重复获取长度,数组不多的时候和普通for循环一样,数组很大时优化效果明显

var arr=[1,2,3,4,5,10,20,30];
    for(var i=0,len=arr.length;i<len;i++){
    console.log(arr[i]);

    }

3, 使用for in方法 进行遍历数组

  var arr = [1,2,3,10,15];
    for(var index in arr){
       // console.log(index);
        console.log(index,arr[index]); 
  }

//所以数组的遍历中千万不要用for in,我们一般对对象的遍历使用。同时上面的i变量是string,并不是number

4, 使用for of 方法进行遍历数组,常用for of  性能比较好

 
 
var arr=[1,2,6,5,8];
for(var value of arr){
//console.log(value);//打印出来是值
        console.log(arr); //打出来是一个数组
    }

 5, 使用forEach方法 ES5推出来的 数组自带循环,主要功能遍历数组,性能不好

   var arr=[1,2,6,5,8];
      var forEach=  arr.forEach(function(value,index){ // 第一参数是值,第二个参数是索引
            console.log('forEach数组:'+index+"--"+value);
        });
    console.log(forEach); // undefined
// forEach循环的缺点就是,你不能使用break语句中断循环,也不能使用retrun返回到外层函数

6, 使用map方法遍历数组,和forEach使用方式以及语法一样,但是性能比forEach好很多,推荐使用

 var arr=[1,2,6,5,8];
var arr=[1,2,6,5,8];var dd= arr.map(function(value,index){// 第一参数是值,第二个参数是索引
      console.log('map数组:'+index+"--"+value);
      retrun value*2;
});
console.log(dd);
注意:map遍历数组方式支持retrun,并且返回一个新的数组。

JS对象遍历:

1.for in 来遍历对象

  var object={
             name:"张三",
             age:18,
             sex:"男",
             sing:function(){
                 console.log(this.name+":"+"八九不离十");
             }
         };
         for(var key in object ){
                console.log(key); //打印出来是属性名字
                console.log(object);// 打印出来是对象
            //console.log(key,object.sing());
        }

           

 jQuery遍历数组和对象:

1.each遍历数组

 var arr=["a","b","c","d","e"];
             $.each(arr,function(key,item){
             console.log(item[0]);//是值
            console.log(key);//是索引
             console.log("arr:"+key+"--"+value);
        });

2.each遍历对象

var obj = { one:1, two:2, three:3, four:4};
        $.each(obj,function(key,value){
            console.log("obj:"+key+"--"+value);
        });
//结果:

     obj:one--1
    obj:two--2
    obj:three--3
    obj:four--4

 

猜你喜欢

转载自www.cnblogs.com/kangkang-saonian/p/10002770.html