js中改变原数组的方法以及解决改变原数组的方法

Posted 迷糊的小元宝

tags:

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

改变原数组的方法

  • pop():删除数组最后一个元素,并返回该元素
  • push():在数组尾部添加元素,并返回更新后的数组长度
  • shift():删除数组的第一个元素,并返回该元素
  • unshift():在数组第一位添加元素,并返回更新后的数组长度
  • sort():对数组排序(按字符ASCII进行排序),也可添加回调函数按照想要的规则排序
  • reverse():数组反转
  • splice(index, howmany, 新数据):返回被删除元素所组成的数组。

解决改变原数组的方法

背景:需要一个和原数组相等的数组,并且操作该数组时不影响原数组,方法:深拷贝。

var a = [1, 2, 3];
// 此时需要b等于a,但是改变b时,不影响a

//方法一,slice()
var b1 = a.slice();

//方法二,concat()
var b2 = [].concat(a);

//方法三,JSON.parse(JSON.stringify())
var b3 = JSON.parse(JSON.stringify(a));

//方法四,手写深拷贝方法
var deepCopy = function(obj) {
  if (typeof obj !== ‘object‘) return;
  var newObj = obj instanceof Array ? [] : {};
  for (var key in obj) {
    if (obj.hasOwnProperty(key)) {
      newObj[key] = typeof obj[key] === ‘object‘ ? deepCopy(obj[key]) : obj[key];
    }
  }
  return newObj;
}
var b4 = deepCopy(a);

 

以上是关于js中改变原数组的方法以及解决改变原数组的方法的主要内容,如果未能解决你的问题,请参考以下文章

不改变原数组的方法

数组都有哪些方法? 哪些会改变原数组?

哪些方法改变原数组,哪些方法不改变原数组

JS数组方法中哪些会改变原数组,哪些不会?

js数组的方法中,哪个方法不能改变自身数组牛客网

关于forEach方法能否改变数组中每一项的值