美文网首页
JavaScript_数组

JavaScript_数组

作者: webGai | 来源:发表于2022-08-01 19:15 被阅读0次

    一、 数据结构

    数据结构分为: 逻辑结构、存储结构和算法。

    (一)存储结构

    a. 线性
    • 队列
    • 数组
    • ……
    b. 非线性
    • ……

    二、 数组基本使用

    (一)数组的声明

    a. 第一种
    // 第一种
    var arr1 = [1,2,3,4,5]
    console.log(arr1);  // [1,2,3,4,5]
    
    b. 第二种
    // 第二种声明
    var arr = new Array(10)
    // var arr = new Array(10,9,8)
    // 当Array()中,只有一个数字参数时,代表着数组的长度,而有 多个时,代表数组的值。
    console.log(arr);   // [ , , , , , , , , , ]长度为10
    

    (二)基本属性及用法

    a. 数组长度: .length
    // length为数组的长度
    var arr1 = [1,2,3,4,5]
    console.log(arr1.length);   // 5
    
    b. 访问数组数据: [i]
    //  i 为数组的下标,通过 [i] 访问数组数据
    var arr1 = [1,2,3,4,5]
    console.log(arr1[3]);   //   4,注意!从0开始
    console.log(arr1[ '0' ]);  // 允许使用字符串的形式,如'0',就是获取第一个( '0' 转换为 1 )
    
    c. 数组的赋值
    arr[0] = 10 
    console.log(arr[0]); // arr[0] 被赋值为 10
    

    (三)遍历数组

    a. for循环
    // 数组的遍历
    for (var i = 0 ; i< arr1.length ; i++) {
        console.log(arr1[i]);
    }
    
    b. for in 迭代器 以下标迭代
    // 数组遍历2
    var arr = [1,2,3,4,5]
    for ( var index in arr ) {  // index,作为变量,可任意取名,是每一个元素的下标
        console.log( arr[index] );
    }
    
    c. for of 迭代器 以值迭代
    // 遍历数组
    var arr = [1,2,3,4,5]
    for ( var value of arr ) {  // value,作为变量,可任意取名,是每一个元素的值
        console.log( value );
    }
    

    (四)数组方法

    a. 增加数据
    1) push() 栈方法添加,表示在数组==结尾==添加元素,同时返回数组长度。
    var arr = [1,2,5]
    console.log(arr);   // 1,2,5,12,这里没写错   push()方法会改变原数组
    arr.push(12)
    console.log(arr);   // 1,2,5,12
    console.log(arr.push(12))   // 4 ,返回数组长度
    
    2) unshift() 队列方法添加,表示在数组==开头==添加元素,同时返回数组长度。
    var arr = [1,2,5]
    console.log(arr);   // 12,1,2,5 这里没写错   unshift()方法会改变原数组
    arr.push(12)
    console.log(arr);   // 121,2,5
    console.log(arr.push(12))   // 4 , 返回数组长度
    
    b. 减少数据
    1) pop() 栈方法删除,表示在数组==结尾==删除元素,同时返回删掉的元素。
    var arr = [1,2,5]
    console.log(arr);   // 1,2      pop()方法会改变原数组
    arr.pop()   
    console.log(arr);   // 1,2 
    console.log(arr.pop())  //  5,  返回删掉的这个元素
    
    2) shift() 队列方法删除,表示在数组==开头==删除元素,同时返回删掉的元素。
    var arr = [1,2,5]
    console.log(arr);   // 2,5      shift()方法会改变原数组
    arr.shift()
    console.log(arr);   // 2,5 
    console.log(arr.shift())    //  1,  返回删掉的元素
    
    c. 排序方法
    1) reverse() 反转数组,同时也会改变原来的数组!
    var arr = [1,2,5]
    console.log(arr);   // 5,2,1
    arr.reverse()
    console.log(arr);   // 5,2,1
    
    2) sort() 升序排列,但默认比ASCii的顺序( 第一位先比,以此类推 ),改变原来数组
    var arr= [4,1,7,3,9,2];
    console.log(arr.sort());   //从小到大排序,返回排序后的数组
    console.log(arr);  // 1,2,4,7,9
    

    eg: sort()可带参数!

    // sort()方法中,默认会以ASCii码的数值进行 逐位 比较,所以会产生 ( 2 排在 11 之前 ),所以传入一个函数作为参数
    function compare(a, b) {
        if (a <= b) {
            return -1;  //返回0和-1, 表示不交换值
        }
        return 1;   //返回1, 表示会交换值
    }
    var box = [0, 30 ,21, 5, 77];
    var aseBox = box.sort(compare);   //返回升序的数组
    console.log(box);   // 0 , 5, 21, 30 ,77
    console.log(aseBox);    // 0 , 5, 21, 30 ,77
    
    //  简易写法如下:
    arr.sort(function(a,b) {
        return a-b  //  返回a-b,则为从小到大排列,反之,则为从大到小排列; 
    })
    
    d.其他操作
    1) concat() 进行数组连接,并返回一个新数组
    // 追加数据, 创建一个新数组, 不改变原数组
    var arr = [2, 3, 4, ‘绿箭侠’, ‘黑寡妇’];
    var arr2 = arr.concat(‘美队’, ‘雷神’);
    console.log(arr);   // 2, 3, 4, ‘绿箭侠’, ‘黑寡妇'    // 原数组不改变
    console.log(arr2);  // 2, 3, 4, ‘绿箭侠’, ‘黑寡妇',‘美队’, ‘雷神’
    
    2) slice() 截取 操作,返回新数组

    slice() ---》 [a,b)

    // 不修改原数组, 将原数组中的指定区域数据提取出来
    
    var arr = [100,200,300,400,500]
    var arr1 = arr.slice( 0,3 ) //  [a,b)   
    console.log(arr)    // [100,200,300,400,500] ,不改变原数组
    console.log(arr1)   // [100,200,300],返回的新数组
    
    3) splice() 截取 / 插值 操作,返回新数组

    splice(索引值,个数)

    var arr = [100,200,300,400,500]
    var arr1 = arr.splice( 0,3 )    // 0,1,2 ;从0开始,一共截取三个元素
    console.log(arr)    // [400,500] ,改变原数组!!
    console.log(arr1)   // [100,200,300],返回截取的 新数组
    

    eg:如果是三个参数时:

    splice(索引值,个数,需要插入的内容) 插入的内容也放在索引值后面

    var arr = [100,200,300,400,500]
    var arr1 = arr.splice( 0,3,'我是新来的') 
    console.log(arr)    // [ '我是新来的' , 400 , 500 ] ,改变原数组!!
    console.log(arr1)   // [100,200,300],返回的新数组
    
    4) join() 连接操作,返回连接后的字符串

    连接数组中各个数据,以特定的 '符号' (作为参数传递),将其连接为一个字符串

    var arr = [1,2,3]
    var arr1 = arr.join(',')    // join()中填写连接方式,该例中,以逗号进行连接
    console.log(arr1,arr1.length);      //  '1,2,3'  length:5;返回长度为5的字符串
    
    5) indexOf() 检索数组
    // 语法: 数组.indexOf( 数据 ) // !!! 注意,O要大写
    // 作用: 查找 数据 在数组中的 索引 位置,若多个,则返回第一个 找不到,则返回 -1 ;
    var arr   =   [ 1 , 2  , 1 , 3 ]
    console.log( arr.indexOf(1) );  //  0,返回第一次出现的下标
    console.log( arr.indexOf(4) );  //  -1,没找到 , 返回 -1 
    
    6) forEach() 遍历数组
    // 语法: 数组.forEach(  function (  item  ,  index  ,  arr  ) { }  )
    // 作用: 遍历数组,无返回值;
    var   arr   =   [  1  ,  2  ,  3   ]
    arr.forEach(  function( item , index , arr )  { 
        console.log( item );    // 数组中的每一项
        console.log( index );  //  数组中的索引
        console.log( arr ); //  原数组
    }  )
    
    结果: image.png
    7) map() 映射
    // 语法: 数组.map(  function (  item  ,  index  ,  arr  ) { }  )
    // 作用: 映射数组,返回映射后的新数组;
    var   arr   =   [  1  ,  2  ,  3   ]
    arr.map(  function(  item  ,  index  ,  arr  )  { 
        return  item * 10   // 返回的值
    }  )
    console.log(  arr  )    //  [  10  ,  20  ,  30  ]
    
    8) filter() 过滤,返回满足条件的
    // 语法: 数组.filter(  function (  item  ,  index  ,  arr  ) { }  )
    // 作用: 过滤数组,筛选满足条件的;    返回过滤后的新数组;
    var   arr   =   [  1  ,  2  ,  3   ]
    arr.filter(  function(  item  ,  index  ,  arr  )  { 
        return  item > 2    // 过滤的条件
    }  )
    console.log(  arr  )    //  [  3  ]
    
    9) every() Boolean值,每一项都满足时,返回true
    // 语法: 数组.every(  function (  item  ,  index  ,  arr  ) { }  )
    // 作用: 判断数组 是否 都满足条件;
    var   arr   =   [  1  ,  2  ,  3   ]
    arr.every(  function(  item  ,  index  ,  arr  )  { 
        return  item > 2    // 判断的条件
    }  )
    console.log( arr )  //  false,并不是每一项都满足
    //  eg2:
    arr.every(  function( item , index , arr )  { 
        return  item > 0    // 判断的条件
    }  )
    console.log( arr )  //  true,每一项都满足!
    
    10) some() Boolean值,当有一项都满足时,返回true
    // 语法: 数组.some(  function ( item , index , arr ) { }  )
    // 作用: 判断数组 是否 都满足条件;
    var   arr   =   [ 1 , 2 , 3 ]
    arr.some(  function( item , index , arr )  { 
        return  item > 2    // 判断的条件
    }  )
    console.log( arr )  //  true,有满足条件的
    //  eg2:
    arr.some(  function( item , index , arr )  { 
        return  item < 0    // 判断的条件
    }  )
    console.log( arr )  //  false,  没有满足条件的
    

    相关文章

      网友评论

          本文标题:JavaScript_数组

          本文链接:https://www.haomeiwen.com/subject/pswrwrtx.html