JavaScript實(shí)現(xiàn)顯示函數(shù)調(diào)用堆棧的方法
本文實(shí)例講述了JavaScript實(shí)現(xiàn)顯示函數(shù)調(diào)用堆棧的方法。分享給大家供大家參考,具體如下:
許多大型的JavaScript應(yīng)用程序間的函數(shù)調(diào)用關(guān)系是非常復(fù)雜的,在開(kāi)發(fā)或者調(diào)試過(guò)程中,經(jīng)常需要跟蹤某個(gè)函數(shù)是由哪些函數(shù)調(diào)用后才觸發(fā)執(zhí)行的,弄清楚這些函數(shù)的調(diào)用順序?qū)ξ覀兝斫獯a的數(shù)據(jù)流向是非常重要的。
Firebug提供了console.trace()來(lái)顯示函數(shù)堆棧,在需要調(diào)試的地方加上下面的一行代碼就能顯示該函數(shù)調(diào)用時(shí)的上下文關(guān)系。IE6就沒(méi)有這么方便了,它沒(méi)有提供顯示函數(shù)堆棧的工具,當(dāng)不可避免的需要在IE6下調(diào)試代碼時(shí),使用下面的代碼能夠顯示函數(shù)堆棧(建議將下面的JavaScript代碼保存為console.trace.js,通過(guò)外部引入js的方式引用到頁(yè)面):
JAVASCRIPT代碼如下:
/** * 獲取函數(shù)名稱 * * @param {Function} func 函數(shù)引用 * @return {String} 函數(shù)名稱 */ function getFunctionName(func) { if ( typeof func == 'function' || typeof func == 'object' ) { var name = ('' + func).match(/function\s*([\w\$]*)\s*\(/); } return name && name[1]; } if (!('console' in window)) { window.console = {}; } if (!console.trace) { /** * 顯示函數(shù)堆棧<br/> * 為了和Firebug統(tǒng)一,將trace方法添加到console對(duì)象中 * * @param {Function} func 函數(shù)引用 * * @example function a() { b(); } function b() { c(); } function c() { d(); } function d() { console.trace(); } a(); */ console.trace = function() { var stack = [], caller = arguments.callee.caller; while (caller) { stack.unshift(getFunctionName(caller)); caller = caller && caller.caller; } alert('functions on stack:' + '\n' + stack.join('\n')); } };
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫(huà)特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
javascript設(shè)計(jì)模式 – 裝飾模式原理與應(yīng)用實(shí)例分析
這篇文章主要介紹了javascript設(shè)計(jì)模式 – 裝飾模式,結(jié)合實(shí)例形式分析了javascript裝飾模式基本概念、原理、應(yīng)用場(chǎng)景及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04JavaScript獲取網(wǎng)頁(yè)中第一個(gè)鏈接ID的方法
這篇文章主要介紹了JavaScript獲取網(wǎng)頁(yè)中第一個(gè)鏈接ID的方法,涉及javascript中document.links方法的使用,需要的朋友可以參考下2015-04-04javascript實(shí)現(xiàn)的一個(gè)帶下拉框功能的文本框
這篇文章主要介紹了javascript實(shí)現(xiàn)的一個(gè)帶下拉框功能的文本框,需要的朋友可以參考下2014-05-05微信小程序自定義單選框樣式實(shí)現(xiàn)單選功能
這篇文章主要為大家詳細(xì)介紹了微信小程序自定義單選框樣式實(shí)現(xiàn)單選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07js支持鍵盤(pán)控制的左右切換立體式圖片輪播效果代碼分享
這篇文章主要介紹了js支持鍵盤(pán)控制的左右切換立體式圖片輪播效果,很實(shí)用的代碼,推薦給大家,有需要的小伙伴可以參考下。2015-08-08