JavaScript剩余操作符Rest Operator詳解
剩余操作符
之前這篇文章JavaScript展開(kāi)操作符(Spread operator)介紹講解過(guò)展開(kāi)操作符。剩余操作符和展開(kāi)操作符的表示方式一樣,都是三個(gè)點(diǎn) '…',但是他們的使用場(chǎng)景會(huì)不同。
剩余參數(shù)
定義函數(shù)的時(shí)候,如果函數(shù)的參數(shù)以… 為前綴,則改參數(shù)是剩余參數(shù)(rest parameter)。剩余參數(shù)表示參數(shù)個(gè)數(shù)不確定的參數(shù)列表。在函數(shù)被調(diào)用時(shí),該形參會(huì)成為一個(gè)數(shù)組,數(shù)組中的元素都是傳遞給該函數(shù)的多出來(lái)的實(shí)參的值。
獲取參數(shù)
剩余操作符可以用來(lái)方便地獲取傳進(jìn)來(lái)的參數(shù)。
function sum(a,b,...args){
console.log(args.length); // 傳進(jìn)來(lái)的參數(shù)的個(gè)數(shù) 3
let s = a + b;
if(args && args.length){
args.forEach(i => {s += i});
}
return s;
}
sum(1, 2, 3, 4, 5 ); // 傳進(jìn)來(lái)的參數(shù)的個(gè)數(shù) 3
其中第一個(gè)形參a對(duì)應(yīng)的是1,第二個(gè)形參b對(duì)應(yīng)的2,…args表示的就是[3, 4, 5]。
和arguments的差別
上面剩余參數(shù)args是一個(gè)數(shù)組,而函數(shù)的arguments是一個(gè)偽數(shù)組。應(yīng)此剩余參數(shù)可以使用數(shù)組的相關(guān)方法sort,map,forEach,pop,而arguments不能。
arguments想要變成數(shù)組,可以通過(guò)Array.prototype.slice.call方法,使用剩余操作符可以避免將arguments轉(zhuǎn)為數(shù)組的麻煩。
// 下面的代碼模擬了剩余數(shù)組
function sum(a,b,){
var args = Array.prototype.slice.call(arguments, sum.length);
console.log(args.length); // 傳進(jìn)來(lái)的參數(shù)的個(gè)數(shù) 3
let s = a + b;
args.forEach(i => {s += i});
return s;
}
sum(1, 2, 3, 4, 5 );
而使用剩余操作符,則不需要轉(zhuǎn)化,直接使用,更加方便。
剩余操作符與解構(gòu)賦值
我們知道,ES6 允許按照一定模式,從數(shù)組和對(duì)象中提取值,對(duì)變量進(jìn)行賦值,這被稱為解構(gòu)(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
在解構(gòu)賦值時(shí),可以使用剩余操作符。剩余操作符所操作的變量會(huì)匹配在解構(gòu)賦值中所有其他變量未匹配到的屬性。
比如如下代碼,others會(huì)匹配到first和second對(duì)于屬性的余下的屬性:
const { first, second, ...others } = {
first: 1,
second: 2,
third: 3,
fourth: 4,
fifth: 5
}
first // 1
second // 2
others // { third: 3, fourth: 4, fifth: 5 }
對(duì)象中余下的屬性值被打包起來(lái)構(gòu)造一個(gè)新的對(duì)象賦值給了others。
數(shù)組也可以通過(guò)剩余操作符,把剩余的元素打包成一個(gè)新的數(shù)組賦值給剩余屬性,代碼如下:
let array = [1,2,3,4,5]; let [a,b,...c] = array; // a 1,b 2, c [3,4,5]
剩余操作符和展開(kāi)操作符
某種程度上,可以任務(wù)剩余操作符是展開(kāi)操作符的相反操作。展開(kāi)操作符會(huì)”展開(kāi)“數(shù)組編程多個(gè)元素,剩余操作符會(huì)把多個(gè)元素壓縮成一個(gè)單一的元素。
相關(guān)文章
基于canvasJS在PHP中制作動(dòng)態(tài)圖表
這篇文章主要介紹了基于canvasJS在PHP中制作動(dòng)態(tài)圖表,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
jQuery實(shí)現(xiàn)可收縮展開(kāi)的級(jí)聯(lián)菜單實(shí)例代碼
這篇文章主要是對(duì)利用jQuery實(shí)現(xiàn)可收縮展開(kāi)的級(jí)聯(lián)菜單的實(shí)例代碼進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11
JS打開(kāi)圖片另存為對(duì)話框?qū)崿F(xiàn)代碼
使用JS打開(kāi)圖片另存為對(duì)話框一直都是網(wǎng)頁(yè)應(yīng)用中不可缺少的一部分,本人有些好奇,于是搜集整理了一些實(shí)現(xiàn)代碼,不知道符不符合大眾的口味,在此班門弄斧了,需要的朋友可以了解下2012-12-12
JavaScript 禁止用戶保存圖片的實(shí)現(xiàn)代碼
這篇文章主要介紹了JavaScript 禁止用戶保存圖片的實(shí)現(xiàn)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
js時(shí)間比較 js計(jì)算時(shí)間差的簡(jiǎn)單實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇js時(shí)間比較 js計(jì)算時(shí)間差的簡(jiǎn)單實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08
基于Bootstrap實(shí)現(xiàn)城市三級(jí)聯(lián)動(dòng)
這篇文章主要為大家詳細(xì)介紹了基于BootStrap實(shí)現(xiàn)城市三級(jí)聯(lián)動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
詳解ES6語(yǔ)法之可迭代協(xié)議和迭代器協(xié)議
這篇文章主要介紹了詳解ES6語(yǔ)法之可迭代協(xié)議和迭代器協(xié)議,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01

