javascript arguments使用示例
<script Language="JavaScript">
//第一個參數(shù)值.
function test(a,b,c,d){
alert(arguments[0]);
}
//arguments[0]實際上就是a,同理,arguments[1]就是b,依次c,d
</script>
<script Language="JavaScript">
{
function function_Name(exp1,exp2,exp3,exp4)
{
var umber="";
umber=arguments.length;
alert(umber);
}
function_Name('a','b','c','d'); 都可以調(diào)用
// function_Name("a","b","c","d"); 都可以調(diào)用
}
</script>
1、在JavaScript中,arguments對象是比較特別的一個對象,實際上是當前函數(shù)的一個內(nèi)置屬性。arguments非常類似Array,但實際上又不是一個Array實例。可以通過如下代碼得以證實(當然,實際上,在函數(shù)funcArg中,調(diào)用arguments是不必要寫成funcArg.arguments,直接寫arguments即可)。
Array.prototype.testArg = "test";
function funcArg() {
alert(funcArg.arguments.testArg);
alert(funcArg.arguments[0]);
}
alert(new Array().testArg); // result: "test"
funcArg(10); // result: "undefined" "10"
2、arguments對象的長度是由實參個數(shù)而不是形參個數(shù)決定的。形參是函數(shù)內(nèi)部重新開辟內(nèi)存空間存儲的變量,但是其與arguments對象內(nèi)存空間并不重疊。對于arguments和值都存在的情況下,兩者值是同步的,但是針對其中一個無值的情況下,對于此無值的情形值不會得以同步。如下代碼可以得以驗證。
function f(a, b, c){
alert(arguments.length); // result: "2"
a = 100;
alert(arguments[0]); // result: "100"
arguments[0] = "qqyumidi";
alert(a); // result: "qqyumidi"
alert(c); // result: "undefined"
c = 2012;
alert(arguments[2]); // result: "undefined"
}
f(1, 2);
3、由JavaScript中函數(shù)的聲明和調(diào)用特性,可以看出JavaScript中函數(shù)是不能重載的。
根據(jù)其他語言中重載的依據(jù):"函數(shù)返回值不同或形參個數(shù)不同",我們可以得出上述結(jié)論:
第一:Javascript函數(shù)的聲明是沒有返回值類型這一說法的;
第二:JavaScript中形參的個數(shù)嚴格意義上來講只是為了方便在函數(shù)中的變量操作,實際上實參已經(jīng)存儲在arguments對象中了。
另外,從JavaScript函數(shù)本身深入理解為什么JavaScript中函數(shù)是不能重載的:在JavaScript中,函數(shù)其實也是對象,函數(shù)名是關(guān)于函數(shù)的引用,或者說函數(shù)名本身就是變量。對于如下所示的函數(shù)聲明與函數(shù)表達式,其實含以上是一樣的(在不考慮函數(shù)聲明與函數(shù)表達式區(qū)別的前提下),非常有利于我們理解JavaScript中函數(shù)是不能重載的這一特性。
function f(a){
return a + 10;
}
function f(a){
return a - 10;
}
// 在不考慮函數(shù)聲明與函數(shù)表達式區(qū)別的前提下,其等價于如下
var f = function(a){
return a + 10;
}
var f = function(a){
return a - 10;
}
4、arguments對象中有一個非常有用的屬性:callee。arguments.callee返回此arguments對象所在的當前函數(shù)引用。在使用函數(shù)遞歸調(diào)用時推薦使用arguments.callee代替函數(shù)名本身。
如下:
function count(a){
if(a==1){
return 1;
}
return a + arguments.callee(--a);
}
var mm = count(10);
alert(mm);
- js的隱含參數(shù)(arguments,callee,caller)使用方法
- javascript內(nèi)置對象arguments詳解
- javascript arguments 傳遞給函數(shù)的隱含參數(shù)
- javascript 利用arguments實現(xiàn)可變長參數(shù)
- JS函數(shù)動態(tài)傳遞參數(shù)的方法分析【基于arguments對象】
- Javascript中arguments對象的詳解與使用方法
- JavaScript中使用arguments獲得函數(shù)傳參個數(shù)實例
- JS中call/apply、arguments、undefined/null方法詳解
- 深入理解JS函數(shù)的參數(shù)(arguments)的使用
- JavaScript中arguments的使用方法詳解
相關(guān)文章
一文教你如何像導(dǎo)入JS模塊一樣導(dǎo)入CSS
HTML中通過使用css可以讓網(wǎng)頁的美觀效果更進一步,下面這篇文章主要給大家介紹了如何像導(dǎo)入JS模塊一樣導(dǎo)入CSS的相關(guān)資料,文中給出了詳細的實例代碼,需要的朋友可以參考下2021-09-09React+Typescript實現(xiàn)倒計時Hook的方法
本文主要介紹了React+Typescript實現(xiàn)倒計時Hook的方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09uniapp開發(fā)H5使用formData上傳文件解決方案
我們很多時候上傳文件就是使用FormData,然而uniapp默認不支持FormData類型數(shù)據(jù)的上傳,下面這篇文章主要給大家介紹了關(guān)于uniapp開發(fā)H5使用formData上傳文件的相關(guān)資料,需要的朋友可以參考下2023-12-12JavaScript模仿Pinterest實現(xiàn)圖片預(yù)加載功能
圖片預(yù)加載是web開發(fā)中一種應(yīng)用相當廣泛的技術(shù),比如我們在做圖片翻轉(zhuǎn)顯示等特效的時候,為了讓圖片在轉(zhuǎn)換的時候不出現(xiàn)等待,我們最好是先讓圖片下載到本地,然后在繼續(xù)執(zhí)行后續(xù)的操作。今天本文主要介紹的是利用JS模仿Pinterest圖片社交網(wǎng)站的圖片預(yù)加載功能。2016-10-10重學(xué) JS:為啥 await 不能用在 forEach 中詳解
這篇文章主要介紹了重學(xué) JS:為啥 await 不能用在 forEach 中,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2019-04-04