Javascript中arguments對象詳解
在上篇文章中我們討論了javascript中的默認(rèn)參數(shù),這篇文章,我們來討論下javascript的arguments參數(shù)對象。
如下例的一個(gè)函數(shù),我們?nèi)绾胃鶕?jù)傳入?yún)?shù)的不同來做不同的處理呢?
function addAll () {
// What do we do here?
}
// Should return 6
addAll(1, 2, 3);
// Should return 10
addAll(1, 2, 3, 4);
幸運(yùn)的是,javascript有一個(gè)arguments對象,可以來處理上述情況。arguments對象是一個(gè)類數(shù)組對象,想了解arguments對象的詳細(xì)情況請戳這里,我們使用arguments對象來改變上例:
function addAll () {
var sum = 0;
for (var i = 0; i < arguments.length; i++) {
sum += arguments[i];
}
return sum;
}
// Returns 6
addAll(1, 2, 3);
// Returns 10
addAll(1, 2, 3, 4);
上面我們說過arguments對象是一個(gè)類數(shù)組對象,下面我們來測試下:
function getName() {
console.log(Array.isArray(arguments));
}
//will output false
getName("benjamin");
上述測試結(jié)果可以看出:
它不是一個(gè)數(shù)組對象,那么它和數(shù)組對象有什么不同呢?詳情請戳這里。
執(zhí)行下面例子會拋出一個(gè)錯(cuò)誤:
function sortArgs () {
// Uncaught TypeError: undefined is not a function
sorted = arguments.sort()
return sorted;
}
sortArgs();
我們可以像下面這樣把一個(gè)類數(shù)組對象轉(zhuǎn)換為數(shù)組對象:
function sortArgs () {
// Convert arguments object into a real array
var args = [].slice.call(arguments);
// Now this will work!
sorted = args.sort()
return sorted;
}
//will output [1, 2, 3]
console.log(sortArgs(1,3,2));
如果你感覺這篇文章對你有幫助,希望轉(zhuǎn)給更多需要的人。文章不妥之處,歡迎留言斧正。
- javascript內(nèi)置對象arguments詳解
- js arguments對象應(yīng)用介紹
- Javascript中arguments對象的詳解與使用方法
- Javascript中的arguments對象
- JS中使用變量保存arguments對象的方法
- 深入解析JavaScript中的arguments對象
- 跟我學(xué)習(xí)javascript的arguments對象
- JavaScript中如何通過arguments對象實(shí)現(xiàn)對象的重載
- Javascript學(xué)習(xí)筆記之函數(shù)篇(四):arguments 對象
- js中arguments對象的深入理解
相關(guān)文章
怎樣在JavaScript里寫一個(gè)swing把數(shù)據(jù)插入數(shù)據(jù)庫
在JavaScript里寫一個(gè)swing來實(shí)現(xiàn)確定取消,來決定是否執(zhí)行這個(gè)功能 控制把數(shù)據(jù)插入數(shù)據(jù)庫,接下來介紹實(shí)現(xiàn)方法2012-12-12Javascript基礎(chǔ):運(yùn)算符與流程控制詳解
這篇文章主要給大家介紹了關(guān)于Javascript中運(yùn)算符及流程控制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-10-10javascript基礎(chǔ)第一章 JavaScript與用戶端
javascript基礎(chǔ)第一章 JavaScript與用戶端2010-07-07Javascript模塊化編程(一)AMD規(guī)范(規(guī)范使用模塊)
這個(gè)系列的第一部分介紹了Javascript模塊的基本寫法,今天介紹如何規(guī)范地使用模塊,先想一想,為什么模塊很重要?接下來為您詳細(xì)介紹,感興趣的朋友可以了解下啊2013-01-01JavaScript中setUTCFullYear()方法的使用簡介
這篇文章主要介紹了JavaScript中setUTCFullYear()方法的使用簡介,是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-06-06