深入淺析JavaScript中的arguments對象(強(qiáng)力推薦)
1、在JavaScript中,arguments對象是比較特別的一個對象,實(shí)際上是當(dāng)前函數(shù)的一個內(nèi)置屬性。arguments非常類似Array,但實(shí)際上又不是一個Array實(shí)例??梢酝ㄟ^如下代碼得以證實(shí)(當(dāng)然,實(shí)際上,在函數(shù)funcArg中,調(diào)用arguments是不必要寫成funcArg.arguments,直接寫arguments即可)。
Array.prototype.testArg = "test"; function funcArg() { alert(funcArg.arguments.testArg); alert(funcArg.arguments[]); } alert(new Array().testArg); // result: "test" funcArg(); // result: "undefined" ""
2、arguments對象的長度是由實(shí)參個數(shù)而不是形參個數(shù)決定的。形參是函數(shù)內(nèi)部重新開辟內(nèi)存空間存儲的變量,但是其與arguments對象內(nèi)存空間并不重疊。對于arguments和值都存在的情況下,兩者值是同步的,但是針對其中一個無值的情況下,對于此無值的情形值不會得以同步。如下代碼可以得以驗證。
function f(a, b, c){ alert(arguments.length); // result: "" a = ; alert(arguments[]); // result: "" arguments[] = "qqyumidi"; alert(a); // result: "qqyumidi" alert(c); // result: "undefined" c = ; alert(arguments[]); // result: "undefined" } f(, );
3、由JavaScript中函數(shù)的聲明和調(diào)用特性,可以看出JavaScript中函數(shù)是不能重載的。
根據(jù)其他語言中重載的依據(jù):"函數(shù)返回值不同或形參個數(shù)不同",我們可以得出上述結(jié)論:
第一:Javascript函數(shù)的聲明是沒有返回值類型這一說法的;
第二:JavaScript中形參的個數(shù)嚴(yán)格意義上來講只是為了方便在函數(shù)中的變量操作,實(shí)際上實(shí)參已經(jīng)存儲在arguments對象中了。
另外,從JavaScript函數(shù)本身深入理解為什么JavaScript中函數(shù)是不能重載的:在JavaScript中,函數(shù)其實(shí)也是對象,函數(shù)名是關(guān)于函數(shù)的引用,或者說函數(shù)名本身就是變量。對于如下所示的函數(shù)聲明與函數(shù)表達(dá)式,其實(shí)含以上是一樣的(在不考慮函數(shù)聲明與函數(shù)表達(dá)式區(qū)別的前提下),非常有利于我們理解JavaScript中函數(shù)是不能重載的這一特性。
function f(a){ return a + ; } function f(a){ return a - ; } // 在不考慮函數(shù)聲明與函數(shù)表達(dá)式區(qū)別的前提下,其等價于如下 var f = function(a){ return a + ; } var f = function(a){ return a - ; }
4、arguments對象中有一個非常有用的屬性:callee。arguments.callee返回此arguments對象所在的當(dāng)前函數(shù)引用。在使用函數(shù)遞歸調(diào)用時推薦使用arguments.callee代替函數(shù)名本身。
如下:
function count(a){ if(a==){ return ; } return a + arguments.callee(--a); } var mm = count(); alert(mm);
以上所述是小編給大家介紹的JavaScript中的arguments對象,希望對大家有所幫助,如果大家在參考過程中發(fā)現(xiàn)有任何疑問請給我留言,小編會及時回復(fù)大家的,在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
原生JS實(shí)現(xiàn)手動輪播圖效果實(shí)例代碼
手動輪播圖,為輪播圖中的一種,輪播圖主要有無縫輪播,手動輪播,延遲輪播,切換輪播等等,輪播圖主要用于展現(xiàn)圖片,新出商品,詞條,又能美觀網(wǎng)頁。給網(wǎng)頁中增加動態(tài)效果。接下來通過本文給大家分享原生JS實(shí)現(xiàn)手動輪播圖的實(shí)例代碼,一起看看吧2018-11-11js模仿windows桌面圖標(biāo)排列算法具體實(shí)現(xiàn)(附圖)
需要引入Jquery,如果需要全部功能,請引入jquery-ui和jquery-ui.css,具體實(shí)現(xiàn)步驟如下,感興趣的朋友可以參考下哈2013-06-06webpack結(jié)合express實(shí)現(xiàn)自動刷新的方法
這篇文章主要給大家介紹了關(guān)于webpack結(jié)合express實(shí)現(xiàn)自動刷新的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用webpack具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05ES6 Object方法擴(kuò)展的應(yīng)用實(shí)例分析
這篇文章主要介紹了ES6 Object方法擴(kuò)展的應(yīng)用,結(jié)合實(shí)例形式總結(jié)分析了ES6針對對象方法的擴(kuò)展與優(yōu)化,需要的朋友可以參考下2019-06-06