深入解析JavaScript中的arguments對象
arguments定義
所有的函數都有一個自己的arguments對象,用來儲存它實際接受到的參數,而不局限於函數聲明時所定義的參數列表。它不是數組卻類似數組,具有數組一樣的存取性質及方式,可以由arguments[n]來存取對應的單一參數的值,並擁有數組長度屬性length。但是卻不具有數組的一些方法。可以透過call把arguments轉換成真正的數組,然後進行數組的操作。
var args = Array.prototype.slice.call(arguments);
類別數組
1. 判斷ARGUMENTS是不是數組
alert(arguments instanceof Array); alert(arguments instanceof Object);
2. 如何嚴格的判斷一個資料是數組(ARRAY)類別的實例
function isArray(value){ if (typeof Array.isArray === "function") { return Array.isArray(value); }else{ return Object.prototype.toString.call(value) === "[object Array]"; } }
3. 把數字ARGUMENTS 內建成陣列可以透過prototype找到內建的屬性方法,Array.prototype.slice就是存取Array的內建方法slice。透過slice方法,傳回一個陣列。 call是呼叫一個物件的方法,以另一個物件取代目前物件。
var arg = Array.prototype.slice.call(arguments,0);
var arg = [].slice.call(arguments,0);
function toArray(arguments){ var a = []; for(var i=0;i<arguments.length;i++){ a.unshift(arguments.[i]); } return a; }
function testCaller() { var caller = testCaller.caller; alert(caller); } function aCaller() { testCaller(); } aCaller();
arguments.callee指向正在運行的函數自身,返回正被執行的 Function 對象,也就是所指定的 Function 對象的正文。
注意:arguments.length是實參長度,arguments.callee.length是形參長度,通常用來判斷形參與實參長度是否一致
透過arguments獲得函數的實參,透過arguments.callee獲得函數的形參。
在閉包中應用的也比較廣泛。
var i = 0; function b(num) { if (num < 10) { num++; i++; //如果有参数,callee也要把参数带上; arguments.callee(num); } else { //输出2次 alert("调用了"+i+"次callee!"); } } b(8); Arguments.callee在闭包中的应用,它提供了一种递归调调用的功能。 //用arguments.callee计算10的阶乘,例如: 1×2×3×4×5×6×7.... function c(x) { return x > 1 ? x * arguments.callee(x - 1) : 1 } (10); //输出6 alert(c(3)); //输出3628800 alert(c(10));
function fn(n){ if(n==1) return n; else return n+arguments.callee(n-1); }
function list(type){ var result = "<"+type+"l><li>"; var args = Array.prototype.slice.call(arguments,1); result += args.join("</li><li>"); result += "</li></"+type+"l>"; return result; } var listHtml = list("o","one","two"); console.log(listHtml);
function foo(x){ console.log(arguments); return x; } foo(1,2,3,4); function foo(x){ console.log(arguments); return x; }(1,2,3,4)
(function fn(){ console.log(arguments); }(1,2,3,4)); (function foo(x){ console.log( arguments); return x; })(1,2,3,4) function foo(){ bar.apply(null,arguments); } function bar(x){ console.log(arguments); } foo(1,2,3,4);

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

本文說明瞭如何使用源地圖通過將其映射回原始代碼來調試JAVASCRIPT。它討論了啟用源地圖,設置斷點以及使用Chrome DevTools和WebPack之類的工具。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

深入探討console.log輸出差異的根源本文將分析一段代碼中console.log函數輸出結果的差異,並解釋其背後的原因。 �...
