1. 程式人生 > >如何使用firefox進行網頁js除錯

如何使用firefox進行網頁js除錯

什麼是Firebug

從事了數年的Web開發工作,越來越覺得現在對WEB開發有了更高的要求。要寫出漂亮的HTML程式碼;要編寫精緻的CSS樣式表展示每個頁面模組;要除錯javascript給頁面增加一些更活潑的要素;要使用Ajax給使用者帶來更好的體驗。一個優秀的WEB開發人員需要顧及更多層面,才能交出一份同樣優秀的作業。為幫助廣大正處於Web2.0洪流中的開發人員,在這裡為大家介紹一款輕巧靈活的輔助開發工具。

Firebug是Firefox下的一款開發類外掛,現屬於Firefox的 五星級強力推薦外掛之一。它集HTML檢視和編輯、Javascript控制檯、網路狀況監視器於一體,是開發JavaScript、CSS、HTML和 Ajax的得力助手。Firebug如同一把精巧的瑞士軍刀,從各個不同的角度剖析Web頁面內部的細節層面,給Web開發者帶來很大的便利。這是一款讓 人愛不釋手的外掛,如果你以前沒有接觸過它,也許在閱讀本文之後,會有一試的慾望。筆者在撰寫此文的時候,正逢Firebug釋出1.0正式版,這不能不 說是種巧合。

應用

Firebug外掛雖然功能強大,但是它已經和Firefox瀏覽器無縫地結合在一起,使用簡單直觀。如果你擔心它會佔用太多的系統資源,也可以方便地啟用/關閉這個外掛,甚至針對特定的站點開啟這個外掛。

在安裝好外掛之後,先用Firefox瀏覽器開啟需要測試的頁面,然後點選右下方的綠色按鈕或使用快捷鍵F12喚出Firebug外掛,它會將當前頁面分成上下兩個框架,如圖1所示。

圖1:Firebug外掛展開圖示
firebug外掛展開圖示
從圖1中看到,Firebug有6個主要的Tab按鈕,下文將主要介紹介紹這幾方面的功能。

Console HTML CSS Script Dom Net
控制檯 Html檢視器 Css檢視器 指令碼條時期 Dom檢視器 網路狀況監視

Console 控制檯

控 制臺能夠顯示當前頁面中的javascript錯誤以及警告,並提示出錯的檔案和行號,方便除錯,這些錯誤提示比起瀏覽器本身提供的錯誤提示更加詳細且具 有參考價值。而且在除錯Ajax應用的時候也是特別有用,你能夠在控制檯裡看到每一個XMLHttpRequests請求post出去的引數、 URL,http頭以及回饋的內容,原本似乎在幕後黑匣子裡運作的程式被清清楚楚地展示在你面前。

象C shell或Python shell一樣,你還能在控制檯中檢視變數內容,直接執行javascript語句,就算是大段的javascript程式也能夠正確執行並拿到執行期的資訊。

控制檯還有個重要的作用就是檢視指令碼的log, 從前你也許習慣了使用alert來列印變數,但是Firebug給我們帶來了一個新朋友 —— console.log, 最簡單的列印日誌的語法是這樣的:

CODE:
  1. console.log(“hello world”)

如果你有一堆引數需要組合在一起輸出,可以寫成這樣:

CODE:
  1. console.log(2,4,6,8,”foo”,bar).

Firebug的日誌輸出有多種可選的格式以及語法,甚至可以定製彩色輸出,比起單調的alert,顯然更加方便,限於篇幅,這裡不做詳細說明,但是有志於提高debug效率的讀者,可以到Firebug的官方站點(見附錄)檢視更詳細的教程。

圖2: 在控制檯裡除錯javascript
在控制檯裡除錯javascript

檢視和修改HTML

第一次看到Firebug強大的HTML程式碼檢視器,就覺得它與眾不同,相比於Firefox自帶的HTML檢視器,它的功能強大了許多。 HTML

首 先你看到的是已經經過格式化的HTML程式碼,它有清晰的層次,你能夠方便地分辨出每一個標籤之間的從屬並行關係,標籤的摺疊功能能夠幫助你集中精力分析代 碼。原始碼上方還標記出了DOM的層次,如圖3所示,它清楚地列出了一個hml元素的parent、child以及root元素,配合Firebug自帶 的CSS檢視器使用,會給div+css頁面分析編寫帶來很大的好處。你還可以在HTML檢視器中直接修改HTML原始碼,並在瀏覽器中第一時間看到修改 後的效果,光憑這一點就會讓許多頁面設計師死心塌地地成為Firebug的粉絲了。

有時候頁面中的javascript會根據使用者的動作如滑鼠的onmouseover來動態改變一些HTML元素的樣式表或背景色,HTML檢視器會將頁面上改變的內容也抓下來,並以黃色高亮標記,讓網頁的暗箱操作徹底成為歷史。

利 用Inspect檢查功能,我們還可以用滑鼠在頁面中直接選擇一些區塊,檢視相應的HTML原始碼和CSS樣式表,真正的做到所見即所得,如果你使用了外 部編輯器修改了當前網頁,可以點選Firebug的reload圖片重新載入網頁,它會繼續跟蹤你之前用Inspect選中的區塊,方便除錯。

圖3::HTML檢視器
HTML檢視器

CSS除錯

Firebug的CSS偵錯程式是專為網頁設計師們量身定做的。

如 今的網頁設計言必稱div+css,如果你是用table套出來的HTML頁面,就得按這規矩重構一遍,否則顯得你不夠時髦!用div做出來的頁面的確能 精簡HTML程式碼,HTML標籤減肥的結果就是CSS樣式表的編寫成了頁面製作的重頭戲。Firebug的CSS檢視器不僅自下向上列出每一個CSS樣式 表的從屬繼承關係,還列出了每一個樣式在哪個樣式檔案中定義。你可以在這個檢視器中直接新增、修改、刪除一些CSS樣式表屬性,並在當前頁面中直接看到修 改後的結果。

一個典型的應用就是頁面中的一個區塊位置顯得有些不太恰當,它需要挪動幾個象素。這時候用CSS除錯工具可以輕易編輯它的位置——你可以根據需要隨意挪動象素。
如圖4中正在修改一個區塊的背景色。

提示:如果你正在學習CSS樣式表的應用,但是總記不住常用的樣式表有哪些值,可以嘗試在CSS偵錯程式中選中一個樣式表屬性,然後用上下方向鍵來改變它的值,它會把可能的值一個個遍歷給你看。

圖4: CSS檢視器,能夠直接修改樣式表
圖4: CSS檢視器,能夠直接修改樣式表

視覺化的CSS尺標

我 們可以利用Firebug來檢視頁面中某一區塊的CSS樣式表,如果進一步展開右側Layout tab的話,它會以標尺的形式將當前區塊佔用的面積清楚地標識出來,精確到象素,更讓人驚訝的是,你能夠在這個視覺化的介面中直接修改各象素的值,頁面上 區塊的位置就會隨改動而變化。在頁面中某些元素出現錯位或者面積超出預料值時,該功能能夠提供有效的幫助,你可以籍此分析offset、margin、 padding、size之間的關係,從而找出解決問題的辦法。

圖5:Firebug中的CSS標尺
圖5:Firebug中的CSS標尺

網路狀況監視器

也許有一天,你的老闆或者客戶找到你,抱怨你製作的網頁速度奇慢,你該如何應對?你或許會說這可能是網路問題,或者是電腦配置問題,或者是程式太慢,或者直說是他們的人品問題?不管怎麼說,最後你可能被要求去解決這個有多種可能的問題。

網 絡狀況監視器能幫你解決這個棘手問題。Firebug的網路監視器同樣是功能強大的,它能將頁面中的CSS、javascript以及網頁中引用的圖片載 入所消耗的時間以矩狀圖呈現出來,也許在這裡你能一把揪出拖慢了你的網頁的元凶,進而對網頁進行調優,最後老闆滿意客戶歡喜,你的飯碗也因此而牢固。

網路監視器還有一些其它細節功能,比如預覽圖片,檢視每一個外部檔案甚至是xmlHttpRequests請求的http頭等等。

圖6:網路狀況監視器
圖6:網路狀況監視器

Javascript偵錯程式

這是一個很不錯的javascript指令碼偵錯程式,佔用空間不大,但是單步除錯、設定斷點、變數檢視視窗一個不少。正所謂麻雀雖小,五臟俱全。

如果你有一個網站已經建成,然而它的javascript有效能上的問題或者不是太完美,可以通過面板上的Profile來統計每段指令碼執行的時間,檢視到底是哪些語句執行時間過長,一步步排除問題。

圖7:javascript偵錯程式
圖7:javascript偵錯程式

DOM檢視器

DOM(Document Object Model)裡頭包含了大量的Object以及函式、事件,在從前,你要想從中查到需要的內容,絕非易事,這好比你去了一個巨大的圖書館,想要找到幾本名 字不太確切的小書,眾多的選擇會讓你無所適從。而使用Firebug的DOM檢視器卻能方便地瀏覽DOM的內部結構,幫助你快速定位DOM物件。雙擊一個 DOM物件,就能夠編輯它的變數或值,編輯的同時,你可能會發現它還有自動完成功能,當你輸入document.get之後,按下tab鍵就能補齊為 document.getElementById,非常方便。如果你認為補齊得不夠理想,按下shift+tab又會恢復原狀。用了Firebug的 DOM檢視器,你的javascript從此找到了驅使的物件,Web開發也許就成了一件樂事。

圖8: Dom檢視器
圖8: Dom檢視器

小結

Firebug 外掛提供了一整套web開發所必需的工具。從HTML的編寫,到CSS樣式表的美化調優,以及用javascript指令碼開發,亦或是Ajax應 用,Firebug外掛都會成為你的得力助手。所謂工欲善其事,必先利其器。在Web2.0的時代,言必稱Ajax,動輒就是使用者體驗提升,如果把 Firebug工具用好,必能讓你如虎添翼,將HTML、CSS、javascript整理得服服帖帖,從此成為web開發中的專家級人物。