...arr ES6的函数增强(打散)引例:多维数组降维

先来引入一个例子:通过函数add()来进行计算输入参数的总和

 

 function add(){

    var sum = 0;

    for(var i=0;i<arguments.length;i++){

      sum+=arguments[i];

    }

    return sum;

  }

  console.log(add(1,2,3));

  console.log(add(1,2,3,4,5));

 

  比较传统的函数的求和,如果没有设置参数的数量,每个函数都会自带一个arguments[]数组,用来储存函数的参数,并且访问的方式是通过下标(从0开始)来进行访问!

  但是对于箭头函数()=>{}则会报错;如下

  

 这是因为箭头函数,并没有内置的arguments[]数组,那么这样的解决办法就是使用...arr

注意:三个点后面只能是arr 如果是其他的字符则会是undefined!!!!!

  还有一个功能就是将数组进行打散(首先来复习一下数组的concat函数)

  var arr = [].concat(1,[2,3],4,[5,6]);

 console.log(arr);

结果是1,2,3,4,5,6。(concat函数进行拼接的时候,会把数组进行打散后进行拼接,但是只是打散一次);

 ...数组名(本例为 ...sun):

  var sun=[1,[2,3],4,[5,6]];

 console.log(...sun);// 1,[2,3],4,[5,6]

为了更好的理解我输出sun进行对比:

console.log(sun);如下图

 如何进行多维数组的降维?(打散,concat()函数,递归)

例: 

 var sun=[1,[2,3],4,[5,6,[7,8,9]]];

  function arr(num){

    num=[].concat(...num);

    var bool=num.some(function(elem){

       return Array.isArray(elem);

    })

    if(bool){

      return arr(num);

    }else{

      return num;

    }

  }

  console.log(arr(sun));

输出结果如下图:

                                                                  以上是本人的学习分享,仅供参考,希望能起到抛砖引玉的作用,如果发现错误以及需要补充的地方,还请各位不吝赐教!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ES6数组解构赋值是一种便捷的语法,可以将数组中的元素分配给变量。通过解构赋值,可以轻松地从数组中提取值并将其赋给变量。这种语法可以简化代码,并使代码更易于理解和维护。 使用数组解构赋值,可以按照特定的顺序将数组中的元素赋值给变量。例如,如果我们有一个包含三个元素的数组[1, 2, 3],我们可以使用解构赋值将每个元素分配给对应的变量。代码示例如下: const arr = [1, 2, 3]; const [a, b, c] = arr; console.log(a, b, c); // 输出1, 2, 3 在上面的代码中,我们定义了一个名为arr数组,并使用解构赋值将数组中的第一个元素赋值给变量a,第二个元素赋值给变量b,第三个元素赋值给变量c。最后,我们将这些变量的值打印出来。 需要注意的是,解构赋值的顺序与数组中元素的顺序有关。换句话说,解构赋值的左边的变量必须与数组中的元素的顺序相对应。如果解构赋值的变量数目少于数组中的元素数目,那么多余的元素将被忽略。如果解构赋值的变量数目多于数组中的元素数目,那么多余的变量将被赋值为undefined。 此外,需要注意的是,解构赋值只能用于具有Iterator接口的数据结构。这意味着,只要数据结构具有Iterator接口,就可以使用数组形式的解构赋值来提取值。 总结来说,ES6数组解构赋值是一种方便的语法,可以将数组中的元素分配给变量。它可以简化代码,提高代码的可读性和可维护性。通过数组解构赋值,可以按照特定的顺序将数组中的元素赋值给变量,并且解构赋值只能用于具有Iterator接口的数据结构。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [ES6数组与对象的解构赋值详解](https://download.csdn.net/download/weixin_38621870/12940725)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [ES6-----数组解构](https://blog.csdn.net/zhouzhou20002000/article/details/128325411)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [ES6 数组解构学习](https://blog.csdn.net/QY_99/article/details/126279215)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值