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

首頁 > 開發 > JS > 正文

JavaScript剩余操作符Rest Operator詳解

2024-05-06 16:53:28
字體:
來源:轉載
供稿:網友

剩余操作符

之前這篇文章JavaScript展開操作符(Spread operator)介紹講解過展開操作符。剩余操作符和展開操作符的表示方式一樣,都是三個點 '…',但是他們的使用場景會不同。

剩余參數

定義函數的時候,如果函數的參數以… 為前綴,則改參數是剩余參數(rest parameter)。剩余參數表示參數個數不確定的參數列表。在函數被調用時,該形參會成為一個數組,數組中的元素都是傳遞給該函數的多出來的實參的值。

獲取參數

剩余操作符可以用來方便地獲取傳進來的參數。

function sum(a,b,...args){ console.log(args.length); // 傳進來的參數的個數 3 let s = a + b; if(args && args.length){  args.forEach(i => {s += i}); }  return s;}sum(1, 2, 3, 4, 5 ); // 傳進來的參數的個數 3

其中第一個形參a對應的是1,第二個形參b對應的2,…args表示的就是[3, 4, 5]。

和arguments的差別

上面剩余參數args是一個數組,而函數的arguments是一個偽數組。應此剩余參數可以使用數組的相關方法sort,map,forEach,pop,而arguments不能。

arguments想要變成數組,可以通過Array.prototype.slice.call方法,使用剩余操作符可以避免將arguments轉為數組的麻煩。

// 下面的代碼模擬了剩余數組function sum(a,b,){ var args = Array.prototype.slice.call(arguments, sum.length);  console.log(args.length); // 傳進來的參數的個數 3 let s = a + b; args.forEach(i => {s += i}); return s;}sum(1, 2, 3, 4, 5 );

而使用剩余操作符,則不需要轉化,直接使用,更加方便。

剩余操作符與解構賦值

我們知道,ES6 允許按照一定模式,從數組和對象中提取值,對變量進行賦值,這被稱為解構(Destructuring)。 比如如下代碼:

let array = [1,2,3]let [a,b,c] = array; // a 1, b 2, c 3

再比如如下代碼:

let obj = {a:1,b:2,c:3}let {a,b,c} = obj; // a 1, b 2, c 3

在解構賦值時,可以使用剩余操作符。剩余操作符所操作的變量會匹配在解構賦值中所有其他變量未匹配到的屬性。
比如如下代碼,others會匹配到first和second對于屬性的余下的屬性:

const { first, second, ...others } = { first: 1, second: 2, third: 3, fourth: 4, fifth: 5}first // 1second // 2others // { third: 3, fourth: 4, fifth: 5 }

對象中余下的屬性值被打包起來構造一個新的對象賦值給了others。

數組也可以通過剩余操作符,把剩余的元素打包成一個新的數組賦值給剩余屬性,代碼如下:

let array = [1,2,3,4,5];let [a,b,...c] = array; // a 1,b 2, c [3,4,5]

剩余操作符和展開操作符

某種程度上,可以任務剩余操作符是展開操作符的相反操作。展開操作符會”展開“數組編程多個元素,剩余操作符會把多個元素壓縮成一個單一的元素。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 光泽县| 阿拉善盟| 上杭县| 普洱| 崇文区| 阿鲁科尔沁旗| 公安县| 丽水市| 神木县| 封丘县| 武山县| 甘南县| 赤水市| 博客| 灵丘县| 永新县| 如皋市| 西乌| 武清区| 梁河县| 海盐县| 高邑县| 巴塘县| 桐柏县| 正镶白旗| 三穗县| 长岭县| 桂平市| 滕州市| 日土县| 台北市| 改则县| 鱼台县| 筠连县| 武陟县| 广河县| 崇明县| 黄石市| 杨浦区| 光泽县| 攀枝花市|