zoukankan      html  css  js  c++  java
  • 数组的方法

     数组的方法有很多,其中会改变原数组的包括:

    push():在数组的末端添加元素,并返回更新后的数组的长度

    pop():删除数组的最后一个元素,并返回这个元素

    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);

    不改变原数组的方法:

    concat:连接多个数组,返回新的数组,不改变原数组

    slice:slice(start,end),返回选定元素,不改变原数组

    join:将数组中所有元素以参数作为分隔符放入一个字符串,不改变原数组

    迭代操作:every,some,filter,map, forEach(不返回值)

  • 相关阅读:
    索引唯一性扫描(INDEX UNIQUE SCAN)
    索引范围扫描(INDEX RANGE SCAN)
    算法设计与分析——回溯法算法模板
    操作系统考试复习大纲
    windows cmd 生成文件目录树
    Java 匿名类和lambda表达式
    下载Abook 高等教育出版社网站资料
    操作系统——银行家算法(Banker's Algorithm)
    算法设计与分析——最大团问题(回溯法)
    JVM内存区域
  • 原文地址:https://www.cnblogs.com/ylyw/p/13307337.html
Copyright © 2011-2022 走看看