码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2019-09-13 17:18:32      阅读:97      评论:0      收藏:0      [点我收藏+]

标签:any   删除元素   json   删除   深拷贝   obj   回调   方法   reverse   

改变原数组的方法

  • 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中改变原数组的方法以及解决改变原数组的方法

标签:any   删除元素   json   删除   深拷贝   obj   回调   方法   reverse   

原文地址:https://www.cnblogs.com/Ingots/p/11517018.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!