Javascript中arguments對象詳解
在上篇文章中我們討論了javascript中的默認(rèn)參數(shù),這篇文章,我們來討論下javascript的arguments參數(shù)對象。
如下例的一個函數(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有一個arguments對象,可以來處理上述情況。arguments對象是一個類數(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對象是一個類數(shù)組對象,下面我們來測試下:
function getName() {
console.log(Array.isArray(arguments));
}
//will output false
getName("benjamin");
上述測試結(jié)果可以看出:
它不是一個數(shù)組對象,那么它和數(shù)組對象有什么不同呢?詳情請戳這里。
執(zhí)行下面例子會拋出一個錯誤:
function sortArgs () {
// Uncaught TypeError: undefined is not a function
sorted = arguments.sort()
return sorted;
}
sortArgs();
我們可以像下面這樣把一個類數(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)給更多需要的人。文章不妥之處,歡迎留言斧正。
相關(guān)文章
怎樣在JavaScript里寫一個swing把數(shù)據(jù)插入數(shù)據(jù)庫
在JavaScript里寫一個swing來實現(xiàn)確定取消,來決定是否執(zhí)行這個功能 控制把數(shù)據(jù)插入數(shù)據(jù)庫,接下來介紹實現(xiàn)方法2012-12-12
Javascript基礎(chǔ):運(yùn)算符與流程控制詳解
這篇文章主要給大家介紹了關(guān)于Javascript中運(yùn)算符及流程控制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-10-10
javascript基礎(chǔ)第一章 JavaScript與用戶端
javascript基礎(chǔ)第一章 JavaScript與用戶端2010-07-07
Javascript模塊化編程(一)AMD規(guī)范(規(guī)范使用模塊)
這個系列的第一部分介紹了Javascript模塊的基本寫法,今天介紹如何規(guī)范地使用模塊,先想一想,為什么模塊很重要?接下來為您詳細(xì)介紹,感興趣的朋友可以了解下啊2013-01-01
JavaScript中setUTCFullYear()方法的使用簡介
這篇文章主要介紹了JavaScript中setUTCFullYear()方法的使用簡介,是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-06-06

