js数组及其遍历方式

Posted 木子李和三点水

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js数组及其遍历方式相关的知识,希望对你有一定的参考价值。

JS数组可以看作一个特殊的对象,有属性和值

数组的定义:

  let arr=[1,2,"abc",true],JS是弱类型语言,数组中元素可以是不同类型的,boolean类型放入值就是对应的字符串true或false

 let arr=[1,"a",true];
        for(let i=0;i<arr.length;i++){
            console.log(typeof arr[i]);
            console.log(arr[i]);
        }

          

length属性:

  表示数组的长度,元素的个数,length属性是可变的,这一点需要特别注意。当length属性被设置得更大时,整个数组的状态事实上不会发生变化,仅仅是length属性变大;当length属性被设置得比原来小时,则原先数组中索引大于或等于length的元素的值全部被丢失

     let arr=[1,"a",false];
        console.log(arr[2]);
        arr.length=2;
        console.log(arr[2]);

可以看出,将length设置到小于定义时,值将丢失,显示未undefined,同理,增大length,值默认为undefined

 

 

数组的遍历:

let arr=[1,2,"abc",true], 数组默认的索引是从0开始的数字,但是类型为字符串!!!!

{

 "0":1,

 "1":2,

 "2":"abc",

 "3":"true"

}

方式1:普通for循环

   for(let i=0;i<arr.length;i++){
  console.log(arr[i]);
}
可以遍历到索引为数字(能转成数字的字符串)的元素(包含undefined),索引的类型是其他的,遍历不到

 let arr=[1,2,"a",false];
        for(let i=0;i<arr.length;i++){
            console.log(arr[i]);
        }

 

 

 当进行"添加元素"的操作时:

let arr=[1,2,"a",false];
        arr[8]=9;//1
        arr["8"]=9;//2
        arr["adc"]="abc";//3
        for(let i=0;i<arr.length;i++){
            console.log(arr[i]);
        }

//1 //2    元素自动补undefined,索引为数字,或者能转为字符串的元素(“3”,“8”,“12”)

       

//3   普通for不支持非“数字”索引

 

 

 方式2:for~in

    for(let key in arr){  

       }

      将数组作为对象遍历其中的属性,取值arr[key]

let arr=[1,2,"a",false];
        arr[8]=9;//1
        arr["8"]=9;//2
        arr["adc"]="abc";//3
        for (let key in arr) {
            console.log(key+":"+arr[key]);
        }

可以看出,key为下标,如果是在定义时的元素,那么下标就是数字索引,如果是“后来增加”的元素(特别注意的是此时不会增加undefinded元素),那么索引就是“增加”时在方括号内指定的

 

 

 方式3:for~of(ES6引入)

    for(let num of nums){

       }

    将数组中的元素直接获取, 可以遍历到索引为数字(能转成数字的字符串)的元素,包含undefined,索引的类型是其他的,遍历不到

 let arr=[1,2,"a",false];
        arr[8]=9;//1
        arr["8"]=9;//2
        arr["adc"]="abc";//3
        for (let key of arr) {
            console.log(key);
        }

效果和普通for相同

 

 

 

 

以上是关于js数组及其遍历方式的主要内容,如果未能解决你的问题,请参考以下文章

JS几种数组遍历方式总结

JS数组遍历方式总结

JS几种数组遍历方式以及性能分析对比

js 循环遍历变量的几种方式

JS几种数组遍历方式以及性能分析对比(转 未经测试,先mark)

thinkphp 如何想模板的JS代码中传递数组?