欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

教你如何使用firebug調(diào)試功能了解javascript閉包和this

 更新時間:2015年03月04日 09:08:56   投稿:hebedich  
這篇文章主要介紹了教你如何使用firebug調(diào)試功能了解javascript閉包和this,javascript的調(diào)試也是一個比較大的難點,很多基礎(chǔ)的東西都需要自己去摸索,這里將自己的經(jīng)驗分享給大家,希望對大家能夠有所幫助

對于跟我一樣,自學(xué)javascript且沒有其他語言學(xué)習(xí)經(jīng)驗的人來說,一開始的時候,javascript的調(diào)試也是一個比較大的難點,很多基礎(chǔ)的東西都需要自己去摸索,這個過程是非??鄲灥?。

想著趁機(jī)會將上面那篇閉包博文的配圖用firebug再來演示一遍,也算是一點調(diào)試經(jīng)驗分享。

示例代碼如下:

復(fù)制代碼 代碼如下:

function fn(){
  var max = 10;
  return function bar(x){
    if (x > max) {
      console.log(x);
    }
  }
}
var fl = fn(),
  max = 100;
fl(15);
  

選擇firebug——腳本

右側(cè)監(jiān)控欄可以window對象以及變量max、fl、fn。

同時下面也可以看到window的屬性,以location為例,可以直接在“控制臺”運(yùn)行window.location輸出,進(jìn)一步可以window.location.href輸出location的href屬性值。當(dāng)然,一般在引用window對象的屬性和方法時,不需要用“window.xxx”這種形式,而直接使用“xxx”。

言歸正傳,

回到“腳本”欄,通過打“斷點”的方式調(diào)試javascript和查看變量值。

有幾個概念可以先了解下:斷點、單步進(jìn)入、單步跳過、單步退出。這里就不詳敘了。

本次主要是采用設(shè)置斷點、單步進(jìn)入的方式。

可以在左側(cè)行標(biāo)處單擊設(shè)置斷點,斷點右鍵可以正則判斷。

可以設(shè)置多個斷點,“斷點”欄內(nèi)可以刪除已設(shè)置的斷點。

這里就直接在script標(biāo)簽的開始處打斷點并刷新頁面。

此時

1、右邊監(jiān)控區(qū)域原window對象處變成this,并指向window。在“控制臺”輸出this.location會得到location一樣的結(jié)果。

2、全局變量max、fl初始化為undefined

3、fn()是函數(shù)聲明,因為解析器會率先讀取函數(shù)聲明,并使其在執(zhí)行任何代碼之前可用(可以訪問)

點擊右上角的“單步進(jìn)入”按鈕

逐次執(zhí)行代碼并在監(jiān)控區(qū)域查看this、各個變量的值變化以及堆棧的情況??梢院屯扑]的那篇博客相互參照來看。

然后再來一個this的例子
代碼如下:

復(fù)制代碼 代碼如下:

var name = 'The Window';
var obj = {
  name: 'The local',
  getNameFunc: function () {
    console.log(this.name);
    return function () {
      console.log(this.name);
    };
  }
};
var c = obj.getNameFunc();
c();

依然“單步進(jìn)入”,可以看到在執(zhí)行c()這行代碼的時候,進(jìn)入到getNameFunc里面,this從指向window對象變?yōu)閛bj,控制臺輸出‘The local'。

逐步執(zhí)行可以非常清晰的看到整個代碼的運(yùn)行邏輯。

以上就是本文關(guān)于使用Firebug的調(diào)試功能了解javascript閉包和this的方法總結(jié)了,希望大家能夠喜歡

相關(guān)文章

最新評論