数组中的push和concat

  • push的定义

    向数组的末尾添加一个或更多元素,返回值为数组添加元素后的长度。

  • concat的定义

    连接两个或更多的数组,并返回结果。该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。

    // push方法var a = [1,2,3];console.log(a.push(4,5)); // 5a.push(6,7);  console.log(a);  // [1,2,3,4,5,6,7]// concat方法  var a = [1,2,3];var b = [4,5];var c = a.concat(b);  console.log(a,b,c);   // [1,2,3]  [4,5]  [1,2,3,4,5]
  • 两者区别

    • push()是在原数组的基础上修改的,执行push()方法后原数组的值也会变,该方法会改变原数组以及原数组的长度;
    • concat()是先把原数组复制到一个新的数组,然后在新数组上进行操作,所以不会改变原数组的值。
    • 如果参数不是数组,push()和concat()都会直接把参数添加到数组后;如果参数是一个数组push()就会直接把数组添加到原数组后,而concat()会把数组里的值取出来添加到原数组的后面
    // push方法添加数组var x = [5,6,7,8];        x.push(['a','b']);console.log(x);  // [5, 6, 7, 8, Array(2)]  ==>  [5, 6, 7, 8, ['a','b']]// concat方法添加数组 var y = ['s','f','h','k'];        var z = y.concat([2,3]);        console.log(z);  // ['s', 'f', 'h', 'k', 2, 3] // 注意: concat()参数是数组会展开,但只会展开一层var y = ['s','f','h','k'];        var z = y.concat([2,3,['u']]);console.log(z);  // ['s', 'f', 'h', 'k', 2, 3, Array(1)]