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

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

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

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

        理解this

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

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

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

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

        代碼如下:

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

        不知道看官們心里的答案是什么,正確的答案是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)一個(gè)函數(shù)被保存為對象的一個(gè)屬性時(shí),我們稱它為一個(gè)方法。當(dāng)一個(gè)方法被調(diào)用時(shí),this被綁定到該對象。注意加粗的這句是重點(diǎn):

        代碼如下:

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

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

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

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

        代碼如下:

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

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

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

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

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

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

        Apply調(diào)用模式

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

      【淺談如何深入學(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的機(jī)制03-25

      JavaScript中的三種對象04-01

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

      主站蜘蛛池模板: 大渡口区| 日韩久久无码免费看A| 尤物AV无码色AV无码麻豆| 素人激情福利视频| 阳曲县| 日本一区二区三区小视频| 亚洲中文字幕无线乱码va| 久久亚洲中文字幕视频| 马山县| 91精品国产闺蜜国产在线| 亚洲国产一区二区三区视频在线 | 国产成人cao在线| 熟女丝袜av一区二区三区四区| 亚洲视频第一页在线观看| av一区二区精品在线| 罗定市| 瑞丽市| 久草久热这里只有精品| 久久亚洲国产精品婷婷| 极品粉嫩小仙女高潮喷水视频| 丰满少妇棚拍无码视频| 五月婷婷久久中文字幕| 国产精品制服一区二区| 兰考县| 永定县| 泸西县| 米易县| 盐亭县| 武平县| 鄂托克前旗| 曲阳县| 免费一级黄色大片久久久| av中文码一区二区三区| 看黄色亚洲看黄色亚洲| 无码熟妇人妻AV不卡| 亚洲AV无码一区二区三区少妇av| 亚洲国产精品日韩专区av| 国产经典免费视频在线观看| 亚洲一区二区三区在线视频观看| 侯马市| 久久久久亚洲AV片无码乐播|