数组

数组

  • 要取得 Array 的长度,直接访问 length 属性

    var arr = [1, 2, 3.14, 'Hello', null, true];
    console.log(arr.length);
    
  • 直接给 Array 的 length 赋一个新的值会导致 Array 大小的变化

    var arr = [1, 2, 3];
    arr.length; // 3 
    arr.length = 6;
    arr; // arr变为[1, 2, 3, undefined, undefined, undefined] 
    arr.length = 2;
    arr; // arr变为[1, 2]
    
  • Array 可以通过索引把对应的元素修改为新的值,因此,对 Array 的索引进行赋值会直接修改这个 Array

    var arr = ['A', 'B', 'C'];
    arr[1] = 99;
    arr; // arr现在变为['A', 99, 'C']
    
  • 请注意,如果通过索引赋值时,索引超过了范围,同样会引起 Array 大小的变化:

    var arr = [1, 2, 3];
    arr[5] = 'x';
    arr; // arr变为[1, 2, 3, undefined, undefined, 'x']
    
  • 常用方法

    indexOf

    //搜索指定元素的位置
    var arr = [10, 20, '30', 'xyz'];
    arr.indexOf(10); // 元素10的索引为0 
    arr.indexOf(30); // 元素30没有找到,返回-1 
    arr.indexOf('30'); // 元素'30'的索引为2
    

    slice

    //截取数组的一部分,然后返回新的数组
    var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G'];
    arr.slice(0, 3); // 从索引0开始,到索引3结束,但不包括索引3: ['A', 'B', 'C'] 
    arr.slice(3); // 从索引3开始到结束: ['D', 'E', 'F', 'G']
    //如果不给slice传递任何参数,则其会全部截取,可用做复制的数组用途
    var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G'];
    var aCopy = arr.slice();
    aCopy; // ['A', 'B', 'C', 'D', 'E', 'F', 'G'] 
    aCopy === arr; // false
    

    push和 pop

    //push() 向 Array 的末尾添加若干元素
    //pop() 则把 Array 的最后一个元素删除掉
    var arr = [1, 2];
    arr.push('A', 'B'); // 返回Array新的长度: 4 
    arr; // [1, 2, 'A', 'B'] 
    arr.pop(); // pop()返回'B' 
    arr; // [1, 2, 'A'] 
    arr.pop(); arr.pop(); arr.pop(); // 连续pop 3次 
    arr; // [] 
    arr.pop(); // 空数组继续pop不会报错,而是返回undefined 
    arr; // []
    

    unshift和shift

    //同push和pop一样,只不过是从头部进行添加和删除
    var arr = [1, 2];
    arr.unshift('A', 'B'); // 返回Array新的长度: 4 
    arr; // ['A', 'B', 1, 2] 
    arr.shift(); // 'A' 
    arr; // ['B', 1, 2]
    arr.shift(); arr.shift(); arr.shift(); // 连续shift 3次
    arr; // []
    arr.shift(); // 空数组继续shift不会报错,而是返回undefined 
    arr; // []
    

    sort

    //为数组元素进行排序
    var arr = ['B', 'C', 'A'];
    arr.sort();
    arr; // ['A', 'B', 'C']
    

    reverse

    //将整个数组次序进行反转
    var arr = ['one', 'two', 'three'];
    arr.reverse();
    arr; // ['three', 'two', 'one']
    

    splice

    //修改数组的万能方法,即可添加也可删除
    var arr = ['Microsoft', 'Apple', 'Yahoo', 'AOL', 'Excite', 'Oracle'];
    // 从索引2开始删除3个元素,然后再添加两个元素:
    arr.splice(2, 3, 'Google', 'Facebook'); // 返回删除的元素 ['Yahoo', 'AOL', 'Excite']
    arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle']
    // 只删除,不添加: 
    arr.splice(2, 2); // ['Google', 'Facebook'] 
    arr; // ['Microsoft', 'Apple', 'Oracle'] 
    // 只添加,不删除:
    arr.splice(2, 0, 'Google', 'Facebook'); // 返回[],因为没有删除任何元素 
    arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle']
    

    concat

    //将两个数组连接成新的数组,但没有修改原来的数组,而是返回一个新的数组
    var arr = ['A', 'B', 'C'];
    var added = arr.concat([1, 2, 3]);
    added; // ['A', 'B', 'C', 1, 2, 3] 
    arr; // ['A', 'B', 'C']
    //concat() 方法可以接收任意个元素和Array,并且自动把Array拆开,然后全部添加到新的Array里
    var arr = ['A', 'B', 'C'];
    arr.concat(1, 2, [3, 4]); // ['A', 'B', 'C', 1, 2, 3, 4]
    

    join

    //将当前数组中的元素都用指定字符串连接起来
    var arr = ['A', 'B', 'C', 1, 2, 3];
    arr.join('-'); // 'A-B-C-1-2-3'
    

    多维数组

    var arr = [[1, 2, 3], [400, 500, 600], '-'];
    var x = arr[1][2];
    console.log(x); // x应该为500
    
posted @ 2021-05-11 09:25  saxon宋  阅读(42)  评论(0)    收藏  举报