js調(diào)試系列 斷點(diǎn)與動(dòng)態(tài)調(diào)試[基礎(chǔ)篇]
上幾篇文章已經(jīng)為大家介紹了js調(diào)試系列的一些基礎(chǔ)知識(shí),這次亂碼兄弟為大家?guī)砹薺s斷點(diǎn)與動(dòng)態(tài)調(diào)試方法,需要的朋友可以參考下
昨天留的課后練習(xí) 1. 分析 votePost 函數(shù)是如何實(shí)現(xiàn) 推薦 的。
其實(shí)我們已經(jīng)看到了源碼,只要讀下源碼即可知道他是怎么實(shí)現(xiàn)的了。
function votePost(n, t, i) { i || (i = !1); var r = { blogApp: currentBlogApp, postId: n, voteType: t, isAbandoned: i }; $("#digg_tips").css("color", "red").html("提交中..."); $.ajax({ url: "/mvc/vote/VoteBlogPost.aspx", type: "post", dataType: "json", contentType: "application/json; charset=utf-8", data: JSON.stringify(r), success: function(n) { if (n.IsSuccess) { var i = $("#" + t.toLowerCase() + "_count"); r.isAbandoned ? $(i).html(parseInt($(i).html()) - 1) : $(i).html(parseInt($(i).html()) + 1) } $("#digg_tips").html(n.Message) }, error: function(n) { n.status > 0 && (n.status == 500 ? $("#digg_tips").html("抱歉!發(fā)生了錯(cuò)誤!麻煩反饋至contact@cnblogs.com") : $("#digg_tips").html(n.responseText)) } }); }
差不多就這個(gè)樣子的。
ps: 我用的是 sublime text 格式化的代碼,和chrome控制臺(tái)格式化后的結(jié)果有點(diǎn)不同。
也可以試試這個(gè)在線格式化工具,效果差不多:Online JavaScript beautifier
簡單讀過代碼后,可以大致知道,這個(gè)函數(shù)有 3 個(gè)參數(shù),第一個(gè)是 postId,就是文章ID,第二個(gè)是 推薦(digg) 或者 反對(duì)(bury),
但是第三個(gè)一直沒用到,而且默認(rèn)值是 false
往下看,他在 #digg_tips 處顯示 "提交中..." 字符串,接著通過 ajax 提交數(shù)據(jù)給后臺(tái)。
返回?cái)?shù)據(jù)后,如果 n.IsSuccess 是 真 就在對(duì)應(yīng)的 喜歡(#digg_count)或反對(duì)(#bury_count)的計(jì)數(shù)id上 +1,
不過這里看到如果 isAbandoned 的值是 真 的話,就計(jì)數(shù) -1。
那我們可以猜測(cè)第三個(gè)參數(shù)是撤銷推薦或者反對(duì)用的,簡單說就是我點(diǎn)了推薦,但是我現(xiàn)在不想推薦了,可以傳遞第三個(gè)參數(shù) true 實(shí)現(xiàn)取消推薦的作用。
我們稍后測(cè)試下。
接著是在 #digg_tips 處顯示服務(wù)器返回的 n.Message 信息。
如果 ajax 發(fā)生錯(cuò)誤,是 500 錯(cuò)誤就提示 "抱歉!發(fā)生了錯(cuò)誤!麻煩反饋至contact@cnblogs.com" 其他狀態(tài)直接提示服務(wù)器返回的錯(cuò)誤信息。
這就是大致的流程,因?yàn)檫@個(gè)函數(shù)簡單,所以基本上一眼就看出來了。
可能有的新人朋友問了,你怎么知道 currentBlogApp, n, t ,i 是什么值呢?
那我們來進(jìn)行下一步,動(dòng)態(tài)調(diào)試好了。對(duì)于編譯過的項(xiàng)目,動(dòng)態(tài)調(diào)試是非常有用的手段。
先定位到 votePost 源碼處,(這個(gè)昨天說過了,不太懂的話,再回去看看先。)
so easy,我們就定位到了源碼。
接下來我們點(diǎn)下92那個(gè)數(shù)字,進(jìn)行下斷點(diǎn)操作。
為什么不是在91行下斷點(diǎn)呢?
因?yàn)?1行是函數(shù)聲明部分,沒法下斷點(diǎn),我們?cè)诤瘮?shù)要執(zhí)行的代碼處下斷點(diǎn)才行。
看到 91 行的行號(hào)變成藍(lán)色了,表示這個(gè)地方已經(jīng)下了斷點(diǎn)了。同時(shí),我們可以在右側(cè) Breakpoints 一欄里看到已下的斷點(diǎn)。
Breakpoints 這個(gè)一欄是管理所有斷點(diǎn)的,可以方便的跳轉(zhuǎn)到對(duì)應(yīng)斷點(diǎn)的位置出,以后常常會(huì)用到哦。
現(xiàn)在下完斷點(diǎn)了,我們回頭點(diǎn)下 推薦。。(雖然感覺我在騙推薦,不過我真心沒這么想,當(dāng)初是隨便找了個(gè)按鈕當(dāng)練習(xí)的。)
當(dāng)你點(diǎn) 推薦 按鈕的時(shí)候,神奇的事情發(fā)生了,并沒有運(yùn)行推薦功能,而是跳到了控制臺(tái) Sources 面板里我們剛剛下的那個(gè)斷點(diǎn)處。
現(xiàn)在,你不僅能在右側(cè) Scope Variables(變量作用域) 一欄處看到當(dāng)前變量,而且還能把鼠標(biāo)直接移到任意變量上,就可以查看該變量的值。
Scope Variables欄目會(huì)顯示當(dāng)前作用域以及他的父級(jí)作用域,以及閉包。
是不是超方便。。(我初學(xué)閉包的時(shí)候,Scope Variables幫了我不少呢。)
我們進(jìn)行下一步,按3次 F10 就可以看到這樣的東西。
我們每按一次 F10 會(huì)執(zhí)行一條語句,剛才按了3次,就是執(zhí)行到了 $("#digg_tips").css("color", "red").html("提交中...");
所以我們可以在頁面上看到 #digg_tips 顯示提交中的字樣。
可是當(dāng)我們?cè)俅伟?F10 的時(shí)候,發(fā)現(xiàn)他一路執(zhí)行下去,而沒有進(jìn)入 ajax 內(nèi)部的回調(diào)函數(shù)。
這是個(gè)糾結(jié)的問題,也是我要重點(diǎn)說的。
像這種回調(diào)函數(shù),特別是異步的,我們要在回調(diào)函數(shù)內(nèi)部再次下一個(gè)斷點(diǎn)。
所以我們?cè)?96 行再下個(gè)斷點(diǎn)即可,現(xiàn)在我們?cè)冱c(diǎn)一下 推薦 依然停在了 92 行,我們直接按 F8 就可以在 ajax 的回調(diào)函數(shù)處斷下了。
現(xiàn)在,我們就可以調(diào)試回調(diào)數(shù)據(jù)了,同時(shí)可以發(fā)現(xiàn)右側(cè) Scope Variables 多了一個(gè) Closure 的東西,這個(gè)就是閉包。
如果現(xiàn)在理解不了,那就過,這東西要大篇幅介紹,不是三言兩句就能講明白的,反正控制臺(tái)很強(qiáng)大就對(duì)了。
在看到閉包的同時(shí),我們也看到 ajax 的返回?cái)?shù)據(jù) n,很明顯,我的 IsSuccess 屬性為 false 沒有成功,因?yàn)樗祷亓艘粋€(gè)信息 "不能推薦自己的內(nèi)容"。
是不是很有意思,動(dòng)態(tài)調(diào)試,讓尋找BUG變得 so easy。
接下來,我們來實(shí)驗(yàn)第三個(gè)參數(shù)。
我們?cè)诳刂婆_(tái)輸入 votePost(cb_entryId, 'Digg', true); 然后回車。
同樣停在了92行的斷點(diǎn)處,這個(gè)里就不調(diào)試了,直接F8進(jìn)入 ajax 的回調(diào)函數(shù)出。
在這里我們非常清楚的看到,當(dāng)?shù)谌齻€(gè)參數(shù)為 true 的時(shí)候,確實(shí)是取消推薦了,同時(shí)你可以看到推薦數(shù)確實(shí) -1 了,哪怕刷新也一樣。
本次我們用到了兩個(gè)快捷鍵 F10 和 F8,明天詳細(xì)介紹,今天先學(xué)會(huì)基礎(chǔ)調(diào)試先。
課后練習(xí):(提高下難度)
1. 查看下面評(píng)論的 提交評(píng)論 按鈕,并找到他的事件。(jQuery 綁定的)
2. 動(dòng)態(tài)調(diào)試這個(gè) 提交評(píng)論 事件的執(zhí)行過程。
如果不會(huì)這個(gè)練習(xí),推薦看下 《淺談 jQuery 事件源碼定位問題》,有詳細(xì)分析哦。
本文來自:博客園博主 亂碼 的文章。http://www.cnblogs.com/52cik/
相關(guān)文章
JavaScript仿京東實(shí)現(xiàn)秒殺倒計(jì)時(shí)案例詳解
這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript實(shí)現(xiàn)京東秒殺倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),感興趣的小伙伴們可以參考一下2022-03-03js的繼承方法小結(jié)(prototype、call、apply)(推薦)
這篇文章主要介紹了js的繼承方法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Javascript遍歷Html Table示例(包括內(nèi)容和屬性值)
這篇文章主要介紹了Javascript如何遍歷Html Table(包括內(nèi)容和屬性值),需要的朋友可以參考下2014-07-07JavaScript中對(duì)象property的刪除方法介紹
這篇文章主要介紹了JavaScript中對(duì)象property的刪除方法介紹,本文主要是對(duì)delete操作符的介紹,需要的朋友可以參考下2014-12-12利用JavaScript實(shí)現(xiàn)檢測(cè)用戶是否在線功能
這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript實(shí)現(xiàn)檢測(cè)用戶是否在線功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-12-12淺談如何使用webpack構(gòu)建多頁面應(yīng)用
這篇文章主要介紹了淺談如何使用webpack構(gòu)建多頁面應(yīng)用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05javascript實(shí)現(xiàn)左右緩動(dòng)動(dòng)畫函數(shù)
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)左右緩動(dòng)動(dòng)畫函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11