輕鬆學習 JavaScript——第 2 部分:函式中的 Rest 引數
本文由碼農網 – 小峰原創翻譯,轉載請看清文末的轉載要求,歡迎參與我們的付費投稿計劃!
JavaScript函式可以使用任意數量的引數。與其他語言(如C#和Java)不同,你可以在呼叫JavaScript函式時傳遞任意數量的引數。JavaScript函式允許未知數量的函式引數。在ECMAScript 6之前,JavaScript有一個變數來訪問這些未知或可變數目的引數,這是一個類似陣列的物件,並非一個陣列。細想以下程式碼來理解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物件用於訪問未知或可變的函式引數。即使arguments使用length屬性和方括號,它也不是一個真正的JavaScript陣列。你不能對arguments物件使用其他JavaScript陣列方法,如pop,push,slice等。在使用arguments時存在的一些問題是:
- JavaScript函式arguments物件不是一個真正的JavaScript陣列;因此,你不能使用其他陣列方法,如pop,push,slice等。
- 在內部函式中訪問外部函式的arguments物件是很困難的。要訪問的話,你需要在變數中分配外部函式的arguments函式,然後在內部函式中使用它。
- 如果你想要使用arguments物件作為陣列,那麼你需要通過Aarry.prototype.slice手動轉換。
ECMAScript 6引入了一個新功能,Rest引數,它表示一個未知數量的引數作為函式中的一個陣列。它不僅將額外的參數列示為陣列,還解決了arguments物件的許多問題。使用rest引數重寫上面的add函式。
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引數定義為…theArgs或… args。如果最後命名的函式引數以…(三個點)作為字首,那麼它將成為函式的rest引數。JavaScript函式的rest引數是純JavaScript陣列。在上面的程式碼中,…theArgs是函式add的rest引數,因為它是唯一的命名引數,且也以…(三個點)作為字首。由於rest引數是JavaScript陣列,所以你可以對rest引數theArgs執行諸如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函式的rest引數也可以與其他引數一起工作。如果你不想在rest引數陣列中包含特定引數的話,那麼你可能需要在函式中使用其他命名引數。細想以下程式碼塊:
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);
對於第一次函式呼叫,6和9將分別分配給num1和num2。對於第二個函式呼叫,7和56將被分配給num1和num2。啟動第三個引數的引數將被分配給rest引數陣列。請記住,前兩個引數不會成為rest引數陣列的一部分。所以,如果你打算將所有的值都包含在rest引數中,那麼你應該一開始就將它們定義為用逗號分隔的命名引數。下面給出的程式碼將會導致錯誤:
function add(num1, ...theArgs,num2){ console.log(num1); console.log(num2); console.log(theArgs.length); }
在上面的程式碼中,rest引數不是最後一個引數,所以JavaScript會丟擲錯誤。rest引數必須是最後一個正式引數。
JavaScript允許你破壞rest引數,這意味著你可以將rest變數資料解包為不同的變數名稱。請看下面的程式碼:
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);
第一次函式呼叫,將分配a = 6,b = undefined,c = undefined,第二次函式呼叫,將分配a = 7,b = 56,c = 9。在此例子中,函式將忽略傳遞的任何額外的引數。
JavaScript函式的rest引數是對arguments物件使用函式未知引數的一個巨大改進。它是一個純JavaScript陣列;因此,你可以對它使用所有陣列方法。你可以將rest變數資料解包到命名變數中。你可以給rest引數指定任何名稱,這又是一個使用arguments關鍵字的重大改進。
在“輕鬆學習JavaScript”系列的下一篇文章中,我們將介紹JavaScript函式中的預設引數,敬請期待。
系列目錄
輕鬆學習 JavaScript——第 1 部分:瞭解 let 語句
輕鬆學習 JavaScript——第 2 部分:函式中的 Rest 引數
輕鬆學習 JavaScript——第 3 部分:函式中的預設引數
輕鬆學習 JavaScript——第 4 部分:函式中的 arguments 物件
輕鬆學習 JavaScript——第 5 部分:簡化函式提升
輕鬆學習 JavaScript——第 6 部分:JavaScript 箭頭函式
輕鬆學習 JavaScript——第 7 部分:物件屬性描述符
輕鬆學習 JavaScript——第 8 部分:JavaScript 中的類
譯文連結:http://www.codeceo.com/article/easy-javascript-02-rest.html
英文原文:Easy JavaScript Part 2: What Is the Rest Parameter in a Function?
翻譯作者:碼農網 – 小峰
[ 轉載必須在正文中標註並保留原文連結、譯文連結和譯者等資訊。]
相關文章
- 輕鬆學習 JavaScript (2):函式中的 Rest 引數JavaScript函式REST
- 輕鬆學習 JavaScript——第 3 部分:函式中的預設引數JavaScript函式
- 輕鬆學習 JavaScript——第 4 部分:函式中的 arguments 物件JavaScript函式物件
- 輕鬆學習 JavaScript——第 6 部分:JavaScript 箭頭函式JavaScript函式
- 輕鬆學習 JavaScript (3):函式中的預設引數JavaScript函式
- 輕鬆學習 JavaScript——第 5 部分:簡化函式提升JavaScript函式
- 輕鬆學習 JavaScript——第 8 部分:JavaScript 中的類JavaScript
- 輕鬆學習 JavaScript (4):函式中的 arguments 物件JavaScript函式物件
- 輕鬆學習 JavaScript(6):JavaScript 箭頭函式JavaScript函式
- 輕鬆學習 JavaScript——第 1 部分:瞭解 let 語句JavaScript
- 輕鬆學習 JavaScript(5):簡化函式提升JavaScript函式
- 輕鬆學習 JavaScript——第 7 部分:物件屬性描述符JavaScript物件
- 輕鬆學習 JavaScript(8):JavaScript 中的類JavaScript
- 學會JavaScript函數語言程式設計(第2部分)JavaScript函數程式設計
- 怎麼輕鬆學習JavaScriptJavaScript
- JavaScript學習總結(四)function函式部分JavaScriptFunction函式
- Javascript函式引數求值——Thunk函式JavaScript函式
- JavaScript學習第三天(函式的定義,引數,閉包)JavaScript函式
- 物聯網學習教程—函式引數和函式的值函式
- JavaScript函式傳遞引數JavaScript函式
- JavaScript函式引數傳遞JavaScript函式
- 學習筆記:javascript中的Generator函式筆記JavaScript函式
- 程式中的函式引數函式
- 輕鬆理解 Transformers(2):Attention部分ORM
- 第 8 節:函式-函式定義和引數函式
- javascript函式引數和函式內同名變數的關係JavaScript函式變數
- 學習javaScript必知必會(1)~js介紹、函式、匿名函式、自呼叫函式、不定長引數JavaScriptJS函式
- 學會JavaScript函數語言程式設計(第3部分)JavaScript函數程式設計
- Yii2 - Active Record 輕鬆學習
- JavaScript 函式引數解構物件JavaScript函式物件
- JavaScript replace()第二個引數為函式時的引數JavaScript函式
- golang學習之路之函式可變引數Golang函式
- 函式定義、函式的引數、函式的預設引數函式
- JavaScript進階系列01,函式的宣告,函式引數,函式閉包JavaScript函式
- 輕鬆學習 JavaScript(1):瞭解 let 語句JavaScript
- javascript獲取函式定義的引數個數JavaScript函式
- javascript的函式的引數是區域性變數JavaScript函式變數
- 函式中引數傳值函式