国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

ES6基礎之展開語法(Spread syntax)

2019-11-19 12:05:19
字體:
來源:轉載
供稿:網友

展開語法用"..."進行表示,展開語法將可迭代的對象拆分成獨立的值(語法層面展開)。擴展語法通常用于將可迭代的對象的值傳遞到函數的參數中。今天小編將從以下方面進行介紹:

  • 函數傳參中的應用
  • 數組的相關應用
  • 剩余參數的應用
  • 函數傳參中的應用

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"

小節

今天的內容就到這里,展開語法是不是特別的酷啊,在日后的開發中,我們盡量使用新的語法糖替代舊的寫法。讓我們代碼看起來更加干凈、整潔、易懂。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 白山市| 吉首市| 天祝| 雷山县| 云和县| 湘乡市| 和平县| 广丰县| 竹溪县| 磴口县| 台湾省| 望城县| 定远县| 马关县| 岳阳县| 将乐县| 云浮市| 稻城县| 武清区| 泗阳县| 松原市| 哈密市| 禄劝| 遵义市| 竹山县| 屏东市| 四平市| 黔东| 盐池县| 高唐县| 体育| 南靖县| 松潘县| 长沙市| 焦作市| 大悟县| 阳谷县| 贡嘎县| 郓城县| 息烽县| 浦江县|