时间:2021-05-28
展开语法用"..."进行表示,展开语法将可迭代的对象拆分成独立的值(语法层面展开)。扩展语法通常用于将可迭代的对象的值传递到函数的参数中。今天小编将从以下方面进行介绍:
ES6之前,如果我们希望将数组作为参数分别传递给函数中的参数,我们可以使用Function的apply()方法。如下段代码所示:
function myFunction(a, b) { return a + b;}var data = [1, 4];var result = myFunction.apply(null, data);console.log(result); //Output "5”从上述代码,apply方法接受一个数组,将它们分拆成单独参数传递函数进行调用。
ES6的展开语法能让我们以更简洁的方式进行调用,如下段代码所示:
function myFunction(a, b) { return a + b; }let data = [1, 4];let result = myFunction(...data);console.log(result); //Output "5”代码运行期间,JavaScript解释器调用myFunction之前,将会用1,4表达式替换...运算符:
let result = myFunction(...data);上述代码将会进行如下转换:
let result = myFunction(1,4);替换后,函数中的代码将会继续执行。
数组的相关应用
数组的合并
展开语法可将数组添加到另外一个数组中,成为其中的一部分。
let array1 = [2,3,4];let array2 = [1, ...array1, 5, 6, 7];console.log(array2); //Output "1, 2, 3, 4, 5, 6, 7”代码运行期间,如下代码:
let array2 = [1, ...array1, 5, 6, 7];上述代码将会替换成如下代码:
let array2 = [1, 2, 3, 4, 5, 6, 7];在push方法中的运用
有时候,我们需要将一个数组的内容追加到另一个数组中,ES6之前我们可以这么做,如下段代码所示:
var array1 = [2,3,4];var array2 = [1];Array.prototype.push.apply(array2, array1);console.log(array2); //Output "1, 2, 3, 4”ES6的展开语法能以更简洁的形式实现,如下段代码所示:
let array1 = [2,3,4];let array2=[1];array2.push(...array1);console.log(array2); //Output "1, 2, 3, 4”代码运行期间,如下代码:
array2.push(...array1);上述代码将会替换成如下代码:
array2.push(2, 3, 4);传递多个数组参数
我们可以使用展开语法传递多个数组进行参数传递,如下段代码所示:
let array1 = [1];let array2 = [2];let array3 = [...array1, ...array2, ...[3, 4]];//multi arrayspreadlet array4 = [5];function myFunction(a, b, c, d, e) { return a+b+c+d+e;}let result = myFunction(...array3, ...array4); //multi array spreadconsole.log(result); //Output "15”剩余参数的应用
我们知道JS函数内部有个arguments对象,可以拿到全部实参。现在ES6给我们带来了一个新的对象,可以拿到除开始参数外的参数,即剩余参数,我们可以使用展开语法...进行获取。
ES6之前,我们可以这样获取剩余参数,如下段代码所示:
function myFunction(a, b) { const args = Array.prototype.slice.call(arguments, myFunction.length); console.log(args);}myFunction(1, 2, 3, 4, 5); //Output "3, 4, 5”ES6中,上述代码我们可以这样改下,如下段代码所示:
function myFunction(a, b, ...args) { console.log(args); //Output "3, 4, 5"}myFunction(1, 2, 3, 4, 5);是不是很简单,有个我们需要注意的事,一旦函数中的参数第一个参数使用剩余参数,就不能声明第二个非剩余参数,否则将会抛出错误。例如下段代码所示:
function fn(...rest,foo) {} //Output "SyntaxError: Rest parameter must be last formal parameter"小节
今天的内容就到这里,展开语法是不是特别的酷啊,在日后的开发中,我们尽量使用新的语法糖替代旧的写法。让我们代码看起来更加干净、整洁、易懂。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
使用ES6语法重构React组件在AirbnbReact/JSXStyleGuide中,推荐使用ES6语法来编写react组件。下面总结一下使用ES6class
本文实例讲述了ES6(ECMAScript6)新特性之模板字符串用法。分享给大家供大家参考,具体如下:ES6引入了一种新型的字符串字面量语法,我们称之为模板字符
开始之前阅读本文需要对以下几项有一定了解ECMAScript6文章中大量用到了ES6语法,比如解构赋值和函数参数默认值、剩余参数、展开语法、箭头函数等。Hook
其实es6的面向对象很多原理和机制还是ES5的,只不过把语法改成类似php和java老牌后端语言中的面向对象语法.一、用es6封装一个基本的类classPers
本文实例讲述了es6数组之扩展运算符操作。分享给大家供大家参考,具体如下:扩展运算符(spread)是三个点(…)。它好比rest参数的逆运算,将一个数组转为用