久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

輕松學(xué)習(xí) JavaScript——第 2 部分:函數(shù)中的 Rest 參數(shù)

 云夢天涯rqxe9h 2017-11-21

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

function add(){ var result = 0; for(let i=0;iarguments.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;ireturn 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ù)以…(三個點(diǎn))作為前綴,,那么它將成為函數(shù)的rest參數(shù)。JavaScript函數(shù)的rest參數(shù)是純JavaScript數(shù)組,。在上面的代碼中,,…theArgs是函數(shù)add的rest參數(shù),因為它是唯一的命名參數(shù),,且也以…(三個點(diǎn))作為前綴,。由于rest參數(shù)是JavaScript數(shù)組,所以你可以對rest參數(shù)theArgs執(zhí)行諸如push,,pop等操作,,如下面的代碼所示:

function add(...theArgs){ theArgs.push(10); var result = 0; for(let i=0;ivar lastItem = theArgs.pop(); console.log(lastItem); return result; }

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

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允許你破壞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ù)的一個巨大改進(jìn),。它是一個純JavaScript數(shù)組,;因此,你可以對它使用所有數(shù)組方法,。你可以將rest變量數(shù)據(jù)解包到命名變量中,。你可以給rest參數(shù)指定任何名稱,這又是一個使用arguments關(guān)鍵字的重大改進(jìn),。


在“輕松學(xué)習(xí)JavaScript”系列的下一篇文章中,,我們將介紹JavaScript函數(shù)中的默認(rèn)參數(shù),敬請期待,。


譯文鏈接:http://www./article/easy-javascript-05-hoisting.html
英文原文:Easy JavaScript Part 5: Simplifying Function Hoisting
翻譯作者:碼農(nóng)網(wǎng) – 小峰

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn),。請注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多