JavaScript實(shí)現(xiàn)顯示函數(shù)調(diào)用堆棧的方法
本文實(shí)例講述了JavaScript實(shí)現(xiàn)顯示函數(shù)調(diào)用堆棧的方法。分享給大家供大家參考,具體如下:
許多大型的JavaScript應(yīng)用程序間的函數(shù)調(diào)用關(guān)系是非常復(fù)雜的,在開發(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就沒有這么方便了,它沒有提供顯示函數(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)畫特效與技巧匯總》、《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í)現(xiàn)商品秒殺倒計(jì)時(shí)(時(shí)間與服務(wù)器時(shí)間同步)
在一些購(gòu)物商城經(jīng)常看到有很多商品做秒殺活動(dòng),也就是倒計(jì)時(shí),本篇文章給大家介紹Javascript實(shí)現(xiàn)商品秒殺倒計(jì)時(shí)(時(shí)間與服務(wù)器時(shí)間同步),需要的朋友可以了解下2015-09-09
eslint+prettier統(tǒng)一代碼風(fēng)格的實(shí)現(xiàn)方法
這篇文章主要介紹了eslint+prettier 統(tǒng)一代碼風(fēng)格的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
Javascript使用post方法提交數(shù)據(jù)實(shí)例
這篇文章主要介紹了Javascript使用post方法提交數(shù)據(jù),實(shí)例分析了javascript實(shí)現(xiàn)post提交數(shù)據(jù)的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08
JavaScrip調(diào)試技巧之?dāng)帱c(diǎn)調(diào)試
本篇文章給大家介紹javascript調(diào)試技巧之?dāng)帱c(diǎn)調(diào)試,主要介紹使用Firebug、debugger、debugger在程序中加入斷點(diǎn)調(diào)試等,但是這些調(diào)試技巧都不借助于瀏覽器之外的工具,其他瀏覽器主要是opera、safari、chrome和ie8,感興趣的小伙伴一起看看吧2015-10-10
JavaScript 精美貪吃蛇實(shí)現(xiàn)流程
看起來(lái)好像很復(fù)雜的貪吃蛇,到底是怎么用JavaScript去實(shí)現(xiàn)的?下面就來(lái)一步一步地,剖析怎么用JavaScript,放在任意一個(gè)瀏覽器中,把貪吃蛇搞起來(lái)2021-11-11
ES6新特性:使用export和import實(shí)現(xiàn)模塊化詳解
本篇文章主要介紹了ES6新特性:使用export和import實(shí)現(xiàn)模塊化詳解,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07

