溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何在JavaScript函數(shù)中使用Rest 參數(shù)

發(fā)布時間:2021-03-02 15:49:14 來源:億速云 閱讀:247 作者:戴恩恩 欄目:web開發(fā)

這篇文章主要為大家詳細介紹了如何在JavaScript函數(shù)中使用Rest 參數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,發(fā)現(xiàn)的小伙伴們可以參考一下:

JavaScript的特點

1.JavaScript主要用來向HTML頁面添加交互行為。 2.JavaScript可以直接嵌入到HTML頁面,但寫成單獨的js文件有利于結(jié)構(gòu)和行為的分離。 3.JavaScript具有跨平臺特性,在絕大多數(shù)瀏覽器的支持下,可以在多種平臺下運行。

JavaScript函數(shù)可以使用任意數(shù)量的參數(shù)。與其他語言(如C#和Java)不同,你可以在調(diào)用JavaScript函數(shù)時傳遞任意數(shù)量的參數(shù)。JavaScript函數(shù)允許未知數(shù)量的函數(shù)參數(shù)。在ECMAScript 6之前,JavaScript有一個變量來訪問這些未知或可變數(shù)目的參數(shù),這是一個類似數(shù)組的對象,并非一個數(shù)組。細想以下代碼來理解arguments變量:

function add(){
var result = 0; 
for(let i=0;i<arguments.length;i++){
result = result + arguments[i];
}
return result; 
}
var r = add(6,9,3,2);
console.log(r);
var t = add(7,56,9);
console.log(t);

如你所見,arguments對象用于訪問未知或可變的函數(shù)參數(shù)。即使arguments使用length屬性和方括號,它也不是一個真正的JavaScript數(shù)組。你不能對arguments對象使用其他JavaScript數(shù)組方法,如pop,push,slice等。在使用arguments時存在的一些問題是:

JavaScript函數(shù)arguments對象不是一個真正的JavaScript數(shù)組;因此,你不能使用其他數(shù)組方法,如pop,push,slice等。
在內(nèi)部函數(shù)中訪問外部函數(shù)的arguments對象是很困難的。要訪問的話,你需要在變量中分配外部函數(shù)的arguments函數(shù),然后在內(nèi)部函數(shù)中使用它。

如果你想要使用arguments對象作為數(shù)組,那么你需要通過Aarry.prototype.slice手動轉(zhuǎn)換。
ECMAScript 6引入了一個新功能,Rest參數(shù),它表示一個未知數(shù)量的參數(shù)作為函數(shù)中的一個數(shù)組。它不僅將額外的參數(shù)表示為數(shù)組,還解決了arguments對象的許多問題。使用rest參數(shù)重寫上面的add函數(shù)。

function add(...theArgs){
var result = 0; 
for(let i=0;i<theArgs.length;i++){
result = result + theArgs[i];
}
return result; 
}
var r = add(6,9,3,2);
console.log(r);
var t = add(7,56,9);
console.log(t);

你可以將rest參數(shù)定義為…theArgs或… args。如果最后命名的函數(shù)參數(shù)以…(三個點)作為前綴,那么它將成為函數(shù)的rest參數(shù)。JavaScript函數(shù)的rest參數(shù)是純JavaScript數(shù)組。在上面的代碼中,…theArgs是函數(shù)add的rest參數(shù),因為它是唯一的命名參數(shù),且也以…(三個點)作為前綴。

由于rest參數(shù)是JavaScript數(shù)組,所以你可以對rest參數(shù)theArgs執(zhí)行諸如push,pop等操作,如下面的代碼所示:

function add(...theArgs){
theArgs.push(10);
var result = 0; 
for(let i=0;i<theArgs.length;i++){
result = result + theArgs[i];
}
var lastItem = theArgs.pop();
console.log(lastItem);
return result; 
}

JavaScript函數(shù)的rest參數(shù)也可以與其他參數(shù)一起工作。如果你不想在rest參數(shù)數(shù)組中包含特定參數(shù)的話,那么你可能需要在函數(shù)中使用其他命名參數(shù)。細想以下代碼塊:

function add(num1, num2, ...theArgs){
console.log(num1);
console.log(num2);
console.log(theArgs.length);
}
var r = add(6,9,3,2);
var t = add(7,56,9);

對于第一次函數(shù)調(diào)用,6和9將分別分配給num1和num2。對于第二個函數(shù)調(diào)用,7和56將被分配給num1和num2。啟動第三個參數(shù)的參數(shù)將被分配給rest參數(shù)數(shù)組。請記住,前兩個參數(shù)不會成為rest參數(shù)數(shù)組的一部分。所以,如果你打算將所有的值都包含在rest參數(shù)中,那么你應(yīng)該一開始就將它們定義為用逗號分隔的命名參數(shù)。下面給出的代碼將會導(dǎo)致錯誤:

function add(num1, ...theArgs,num2){
console.log(num1);
console.log(num2);
console.log(theArgs.length);
}

在上面的代碼中,rest參數(shù)不是最后一個參數(shù),所以JavaScript會拋出錯誤。rest參數(shù)必須是最后一個正式參數(shù)。

如何在JavaScript函數(shù)中使用Rest 參數(shù)

JavaScript允許你破壞rest參數(shù),這意味著你可以將rest變量數(shù)據(jù)解包為不同的變量名稱。請看下面的代碼:

function add(...[a,b,c]){
return a+b+c; 
}
var r = add(6);
console.log(r);
var t = add(7,56,9);
console.log(t);

第一次函數(shù)調(diào)用,將分配a = 6,b = undefined,c = undefined,第二次函數(shù)調(diào)用,將分配a = 7,b = 56,c = 9。在此例子中,函數(shù)將忽略傳遞的任何額外的參數(shù)。

JavaScript函數(shù)的rest參數(shù)是對arguments對象使用函數(shù)未知參數(shù)的一個巨大改進。它是一個純JavaScript數(shù)組;因此,你可以對它使用所有數(shù)組方法。你可以將rest變量數(shù)據(jù)解包到命名變量中。你可以給rest參數(shù)指定任何名稱,這又是一個使用arguments關(guān)鍵字的重大改進。

以上就是億速云小編為大家收集整理的如何在JavaScript函數(shù)中使用Rest 參數(shù),如何覺得億速云網(wǎng)站的內(nèi)容還不錯,歡迎將億速云網(wǎng)站推薦給身邊好友。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI