中文字幕在线一区二区在线,久久久精品免费观看国产,无码日日模日日碰夜夜爽,天堂av在线最新版在线,日韩美精品无码一本二本三本,麻豆精品三级国产国语,精品无码AⅤ片,国产区在线观看视频

      淺談如何深入學習Javascript中的this關鍵字

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

      淺談如何深入學習Javascript中的this關鍵字

        理解this

      淺談如何深入學習Javascript中的this關鍵字

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

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

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

        代碼如下:

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

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

        代碼如下:

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

        1.方法調用模式

        2.函數調用模式

        3.構造器調用模式

        4.apply調用模式

        而在這些模式當中,對于如何初始化關鍵參數this上是存在不同差異的。

        方法調用模式

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

        代碼如下:

        // 創建myObject。它有一個value屬性和一個increment方法

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

        函數調用模式

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

        代碼如下:

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

        構造器調用模式

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

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

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

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

        Apply調用模式

        因為javascript是一門函數式面向對象編程語言,所以函數可以擁有方法。apply方法讓我們構建一個參數數組并用其去調用其他函數,apply方法接收兩個參數,第一個是將被綁定的this的值,第二個是參數數組。說簡單直接一點就是apply方法能劫持另外一個對象的方法,繼承另外一個對象的屬性. 推薦可以看js中apply方法的使用詳細解析 ,就不擺demo了。

      【淺談如何深入學習Javascript中的this關鍵字】相關文章:

      JavaScript中的with關鍵字03-25

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

      有關深入理解JavaScript中的并行處理的介紹03-30

      JavaScript學習筆記03-30

      在Java中執行JavaScript代碼04-01

      Javascript中typeof 用法歸納04-01

      perl- javascript中class的機制03-25

      JavaScript中的三種對象04-01

      抽象語法樹在JavaScript中的應用03-25

      主站蜘蛛池模板: av在线网站手机播放| 2020久久精品亚洲热综合一本| 九九精品国产99精品| 一区二区三区在线视频免费观看| 99精品国产成人一区二区在线| 久久av一区二区三区播放| 寻乌县| 欧美人与动牲交片免费播放| 亚洲一区二区av偷偷| 亚洲国产成a人v在线观看| 林甸县| 久久国产精品99精品国产987 | 精品偷拍一区二区三区在线看| 亚洲国产精品无码久久九九大片健 | 中文字幕av久久激情亚洲精品| 粗大挺进尤物人妻一区二区| 国产后入内射在线观看| 久久亚洲日本免费高清一区| 亚洲综合1区2区3区| 固镇县| 永丰县| 南昌县| 东宁县| 亚洲国产精一区二区三区性色| 乡宁县| 日本加勒比在线一区二区三区| 日本一区二区三区在线播放| 徐水县| 成人小视频在线观看播放| 平和县| 韩国三级大全久久网站| 伊人色综合九久久天天蜜桃| 国产精品黄片一区二区三区视频 | 阿合奇县| 仙桃市| 亚洲高清有码在线观看| 亚洲午夜久久久久中文字幕久 | 97超级碰碰碰久久久观看| 色中文字幕视频在线观看| 国产午夜亚洲精品不卡免下载| 毛片av在线播放亚洲av网站|