• <sub id="h4knl"><ol id="h4knl"></ol></sub>
    <sup id="h4knl"></sup>
      <sub id="h4knl"></sub>

      <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
      1. <strong id="h4knl"></strong>

      2. 淺談如何深入學(xué)習(xí)Javascript中的this關(guān)鍵字

        時間:2024-08-19 03:01:56 JavaScript 我要投稿
        • 相關(guān)推薦

        淺談如何深入學(xué)習(xí)Javascript中的this關(guān)鍵字

          理解this

        淺談如何深入學(xué)習(xí)Javascript中的this關(guān)鍵字

          this是一個與執(zhí)行上下文(execution context,也就是作用域)相關(guān)的特殊對象。因此,它可以叫作上下文對象(也就是用來指明執(zhí)行上下文是在哪個上下 文中被觸發(fā)的對象)。

          任何對象都可以做為上下文中的this的值。在一些對ECMAScript執(zhí)行上下文和部分this的描述中的 所產(chǎn)生誤解。this經(jīng)常被錯誤的描述成是變量對象的一個屬性。 再重復(fù)一次:

          this是執(zhí)行上下文的一個屬性,而不是變量對象的一個屬性。 這個特性非常重要,因為與變量相反,this從不會參與到標(biāo)識符解析過程。換句話說,在代碼中當(dāng)訪問this的時候,它的值是直接從執(zhí)行上下文中獲取的,并不需要任何作用域鏈查找。this的值只在進入上下文的時候進行一次確定。

          代碼如下:

          hasOwnProperty:是用來判斷一個對象是否有你給出名稱的屬性或?qū)ο蟆2贿^需要注意的是,此方法無法檢查該對象的原型鏈中是否具有該屬性,該屬性必須是對象本身的一個成員。

          不知道看官們心里的答案是什么,正確的答案是true,false。

          代碼如下:

          要弄明白為什么是這樣,就必須要理解上面this所扮演的角色,所指代的對象。在《javascript語言精粹》一書中,指出了在javascript中一共有四種調(diào)用模式:

          1.方法調(diào)用模式

          2.函數(shù)調(diào)用模式

          3.構(gòu)造器調(diào)用模式

          4.apply調(diào)用模式

          而在這些模式當(dāng)中,對于如何初始化關(guān)鍵參數(shù)this上是存在不同差異的。

          方法調(diào)用模式

          當(dāng)一個函數(shù)被保存為對象的一個屬性時,我們稱它為一個方法。當(dāng)一個方法被調(diào)用時,this被綁定到該對象。注意加粗的這句是重點:

          代碼如下:

          // 創(chuàng)建myObject。它有一個value屬性和一個increment方法

          這里,方法increment可以使用this去訪問myObject對象,所以可以改變value的值。而且,this到對象的綁定發(fā)生在調(diào)用的時候。

          函數(shù)調(diào)用模式

          如果一個函數(shù)并非一個對象的屬性時,那么它被當(dāng)作一個函數(shù)來調(diào)用,此時,this被綁定到全局對象,書上說這是js語言設(shè)計的一個缺陷。倘若設(shè)計正確,當(dāng)內(nèi)部函數(shù)被調(diào)用的時,this應(yīng)該仍然綁定到外部函數(shù)的this變量。拋開對語言設(shè)計的正確與否討論,要當(dāng)函數(shù)調(diào)用模式時this變量依舊綁定到該對象,有如下經(jīng)典解決方案:

          代碼如下:

          即是給該方法定義一個變量并且把它賦值為this,那么內(nèi)部函數(shù)就可以通過那個變量訪問到this,按照約定,給那個變量命名為that。

          構(gòu)造器調(diào)用模式

          構(gòu)造器調(diào)用模式即是我一開頭給出的例子所提到的。如果在一個函數(shù)前面帶上new來調(diào)用,那么將創(chuàng)建一個連接到該函數(shù)的prototype成員新對象,同時this將會被綁定到那個新對象上。聽上去十分拗口且難以理解,先再看個demo:

          簡單來說,Quo對象下的this在被用為構(gòu)造一個新實例即new時,this指代的是新生成的myQuo對象而不是Quo對象本身。

          一句話,重點就是:原型中的this不是指的原型對象,而是調(diào)用對象。

          再回過頭看一開始的demo,就很好理解了,在執(zhí)行myTest.fun()時,this指代了myTest對象,所以生成了一個foo屬性值為“banana”,所以myTest.hasOwnProperty("foo")返回值為true。

          Apply調(diào)用模式

          因為javascript是一門函數(shù)式面向?qū)ο缶幊陶Z言,所以函數(shù)可以擁有方法。apply方法讓我們構(gòu)建一個參數(shù)數(shù)組并用其去調(diào)用其他函數(shù),apply方法接收兩個參數(shù),第一個是將被綁定的this的值,第二個是參數(shù)數(shù)組。說簡單直接一點就是apply方法能劫持另外一個對象的方法,繼承另外一個對象的屬性. 推薦可以看js中apply方法的使用詳細解析 ,就不擺demo了。

        《&.doc》
        将本文的Word文档下载到电脑,方便收藏和打印
        推荐度:
        点击下载文档

        【淺談如何深入學(xué)習(xí)Javascript中的this關(guān)鍵字】相關(guān)文章:

        JavaScript中的with關(guān)鍵字03-25

        淺談javascript中的單線程理解03-30

        有關(guān)深入理解JavaScript中的并行處理的介紹03-30

        JavaScript學(xué)習(xí)筆記03-30

        在Java中執(zhí)行JavaScript代碼04-01

        Javascript中typeof 用法歸納04-01

        perl- javascript中class的機制03-25

        JavaScript中的三種對象04-01

        抽象語法樹在JavaScript中的應(yīng)用03-25

        在线咨询
        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码
      3. <sub id="h4knl"><ol id="h4knl"></ol></sub>
        <sup id="h4knl"></sup>
          <sub id="h4knl"></sub>

          <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
          1. <strong id="h4knl"></strong>

          2. 日韩不卡中文字幕在线 | 日本免费高清一区二区三区最新 | 在线观看h的网址 | 日本欧美另类视频在线 | 日韩国产精品一区二区Hd | 亚洲欧美综合少妇 |

            淺談如何深入學(xué)習(xí)Javascript中的this關(guān)鍵字

              理解this

            淺談如何深入學(xué)習(xí)Javascript中的this關(guān)鍵字

              this是一個與執(zhí)行上下文(execution context,也就是作用域)相關(guān)的特殊對象。因此,它可以叫作上下文對象(也就是用來指明執(zhí)行上下文是在哪個上下 文中被觸發(fā)的對象)。

              任何對象都可以做為上下文中的this的值。在一些對ECMAScript執(zhí)行上下文和部分this的描述中的 所產(chǎn)生誤解。this經(jīng)常被錯誤的描述成是變量對象的一個屬性。 再重復(fù)一次:

              this是執(zhí)行上下文的一個屬性,而不是變量對象的一個屬性。 這個特性非常重要,因為與變量相反,this從不會參與到標(biāo)識符解析過程。換句話說,在代碼中當(dāng)訪問this的時候,它的值是直接從執(zhí)行上下文中獲取的,并不需要任何作用域鏈查找。this的值只在進入上下文的時候進行一次確定。

              代碼如下:

              hasOwnProperty:是用來判斷一個對象是否有你給出名稱的屬性或?qū)ο蟆2贿^需要注意的是,此方法無法檢查該對象的原型鏈中是否具有該屬性,該屬性必須是對象本身的一個成員。

              不知道看官們心里的答案是什么,正確的答案是true,false。

              代碼如下:

              要弄明白為什么是這樣,就必須要理解上面this所扮演的角色,所指代的對象。在《javascript語言精粹》一書中,指出了在javascript中一共有四種調(diào)用模式:

              1.方法調(diào)用模式

              2.函數(shù)調(diào)用模式

              3.構(gòu)造器調(diào)用模式

              4.apply調(diào)用模式

              而在這些模式當(dāng)中,對于如何初始化關(guān)鍵參數(shù)this上是存在不同差異的。

              方法調(diào)用模式

              當(dāng)一個函數(shù)被保存為對象的一個屬性時,我們稱它為一個方法。當(dāng)一個方法被調(diào)用時,this被綁定到該對象。注意加粗的這句是重點:

              代碼如下:

              // 創(chuàng)建myObject。它有一個value屬性和一個increment方法

              這里,方法increment可以使用this去訪問myObject對象,所以可以改變value的值。而且,this到對象的綁定發(fā)生在調(diào)用的時候。

              函數(shù)調(diào)用模式

              如果一個函數(shù)并非一個對象的屬性時,那么它被當(dāng)作一個函數(shù)來調(diào)用,此時,this被綁定到全局對象,書上說這是js語言設(shè)計的一個缺陷。倘若設(shè)計正確,當(dāng)內(nèi)部函數(shù)被調(diào)用的時,this應(yīng)該仍然綁定到外部函數(shù)的this變量。拋開對語言設(shè)計的正確與否討論,要當(dāng)函數(shù)調(diào)用模式時this變量依舊綁定到該對象,有如下經(jīng)典解決方案:

              代碼如下:

              即是給該方法定義一個變量并且把它賦值為this,那么內(nèi)部函數(shù)就可以通過那個變量訪問到this,按照約定,給那個變量命名為that。

              構(gòu)造器調(diào)用模式

              構(gòu)造器調(diào)用模式即是我一開頭給出的例子所提到的。如果在一個函數(shù)前面帶上new來調(diào)用,那么將創(chuàng)建一個連接到該函數(shù)的prototype成員新對象,同時this將會被綁定到那個新對象上。聽上去十分拗口且難以理解,先再看個demo:

              簡單來說,Quo對象下的this在被用為構(gòu)造一個新實例即new時,this指代的是新生成的myQuo對象而不是Quo對象本身。

              一句話,重點就是:原型中的this不是指的原型對象,而是調(diào)用對象。

              再回過頭看一開始的demo,就很好理解了,在執(zhí)行myTest.fun()時,this指代了myTest對象,所以生成了一個foo屬性值為“banana”,所以myTest.hasOwnProperty("foo")返回值為true。

              Apply調(diào)用模式

              因為javascript是一門函數(shù)式面向?qū)ο缶幊陶Z言,所以函數(shù)可以擁有方法。apply方法讓我們構(gòu)建一個參數(shù)數(shù)組并用其去調(diào)用其他函數(shù),apply方法接收兩個參數(shù),第一個是將被綁定的this的值,第二個是參數(shù)數(shù)組。說簡單直接一點就是apply方法能劫持另外一個對象的方法,繼承另外一個對象的屬性. 推薦可以看js中apply方法的使用詳細解析 ,就不擺demo了。