成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

解析js中的this對象

firim / 2829人閱讀

摘要:指定為原始值數(shù)字,字符串,布爾值會指向該原始值的自動包裝對象這一點感謝評論區(qū)的讀者補充。

前言

(幾天之前寫了源碼分析之后,感覺太疲憊了,寫一些相對輕巧的內(nèi)容調(diào)劑一下,希望喜歡的同學(xué)可以點個贊和收藏~)
進入正題,this對象在js中是很常見,但是在這里也經(jīng)常會出錯,本文將對常見的this對象的情況做一些總結(jié)

正文
this對象是在函數(shù)運行時,基于函數(shù)的執(zhí)行環(huán)境綁定的。

其實這句話的本質(zhì)就是,誰調(diào)用了函數(shù),this就指向誰

具體的來說,通常有以下幾種情況:

全局函數(shù)

在全局環(huán)境中,this指向Window

 //例子1
  function A() {
    console.log(this)
  }
  A();//Window

上面的例子很簡單,函數(shù)A在全局環(huán)境中執(zhí)行,也就是全局對象Window調(diào)用了函數(shù)。此時this指向Window

對象方法

作為對象方法調(diào)用時,this指向調(diào)用該方法的對象

//例子2
var  b = {
    getThis:function(){
        console.log(this)
    }
}
b.getThis()//b

到這里我們舉的例子都比較簡單易懂,接下來來一個有意思的:

//例子3
  var c = {
    getFunc:function(){
      return function(){
        console.log(this)
      }
    }
  }
  var cFun = c.getFunc()
  cFun()//Window

這個例子和前一個例子不一樣,運行c.getFunc()時,首先返回的是一個匿名函數(shù),我們將這個函數(shù)賦值給cFun,接著在全局環(huán)境中調(diào)用了cFun(),所以此時this指向的還是Window。

如果我們一定要讓這里返回的是c對象呢?在開頭我們說過,this對象是在函數(shù)執(zhí)行時確定的,在例子3中,執(zhí)行c.getFunc()時,this對象指向的還是c,所以我們只要保持住這個this就好了,對上面的代碼稍微改動:

//例子4
  var c = {
    getFunc:function(){
        var that = this //在這里保留住this
      return function(){
        console.log(that)
      }
    }
  }
  var cFun = c.getFunc()
  cFun()//c

這也就是我們經(jīng)??梢栽谝恍┐a中看到var self = this或者var that = this之類的原因了。

call和apply

此時this對象通常指向函數(shù)中指定的this值(注意這里的通常2字,考試要考的)

callapply算是老生常談,但還是稍微介紹下,怕新同學(xué)可能沒接觸過(其實是為了湊點字?jǐn)?shù)),拿call來說,語法是這樣的

fun.call(thisArg, arg1, arg2, ...)

這個方法怎么用呢,看下面的例子:

//例子5
var d = {
    getThis:function(){
        console.log(this)
    }
}
var e = {
   name:"e"http://(給e寫個`name`屬性只是因為覺得孤零零的太難看了~~)
}
d.getThis.call(e)//e

在這里我們就可以看出call函數(shù)的意思了:指定一個對象o1去調(diào)用其他對象o2的方法,此時this對象指向o1

好了,那為什么前面我們說通常呢?因為,有2種例外的情況:

thisArg指定為nullundefined時,this指向window。

thisArg指定為原始值(數(shù)字,字符串,布爾值),this會指向該原始值的自動包裝對象這一點感謝評論區(qū)的讀者補充)。請看:

//例子6
var d = {
    getThis:function(){
        console.log(this)
    }
}
  d.getThis.call(null)//Window
  d.getThis.call(undefined)//Window
  d.getThis.call(1) //Number
  d.getThis.call("hello") //String
  d.getThis.call(true) //Boolean
番外:基本包裝類型

既然講到包裝類型,那這里順便補充介紹一下基本包裝類型:基本包裝類型(包括Boolean,String,Number)是一類特殊的引用類型,它們具有引用類型的基本特征,還具有對應(yīng)的基本類型的特殊行為,舉個例子:

//基本包裝類型
var str = "hello World";
var str2 = s1.substring(2);

首先,str是字符串,字符串是基本數(shù)據(jù)類型,但是在第二行代碼中,str.substring(2)調(diào)用了str的方法,我們知道,基本數(shù)據(jù)類型不是對象,本來是是不應(yīng)該有方法的,但是實際上我們知道string,number類型都有對應(yīng)的方法,因為從內(nèi)存中訪問str時,訪問進入了一種讀取模式,在后臺自動做了以下轉(zhuǎn)換:

創(chuàng)建一個String類型的實例

在實例上調(diào)用相應(yīng)方法

銷毀該實例

特點:自動創(chuàng)建的基本包裝類型的對象只存在于執(zhí)行代碼的瞬間,然后立即銷毀。
那么可以手動創(chuàng)建基本包裝類型嗎?當(dāng)然可以:

var  str = new String("Hello")//注意這里是new一個實例,而不是用String類型轉(zhuǎn)換函數(shù)
typeof(str)//object
var str2 = String(222)//如果使用類型轉(zhuǎn)換函數(shù)得到的還是類型
ypeof(str2)//string

此時的str就是一個顯式創(chuàng)建的基本包裝類型對象,只是一般來說很少這樣去使用

箭頭函數(shù)

es6中的箭頭函數(shù)現(xiàn)在也用的比較頻繁,但是有個需要注意的點是:

函數(shù)體內(nèi)的this對象,就是定義時所在的對象,而不是使用時所在的對象。

其實出現(xiàn)這種情況的根本原因是:箭頭函數(shù)沒有this對象,所以箭頭函數(shù)的this就是外層代碼的this

//例子7
  var f = {
      getThis:()=>{
          console.log(this)
      }
  }
  f.getThis()//Window

這個例子和前面例子2是基本一樣的,只是把普通函數(shù)改寫成箭頭函數(shù),但是此時的this對象已經(jīng)指向了外層的Window。

考慮到這一點可能不好理解,我們再看幾個例子:

//例子8
  var g = {
    getThis:function(){
      return function(){console.log(this)}
    }
  }
  var h = {
    getThis:function(){
      return ()=> console.log(this)
    }
  }
  g.getThis()()//Window
  h.getThis()()//h

這個例子里,g的getThis寫法就和之前的例子3一樣,由于函數(shù)在全局環(huán)境中運行,所以此時this指向Window;h的getThis使用了箭頭函數(shù),所以this指向了外層代碼塊的this所以,此時this指向的是h。

總結(jié)

小結(jié)一下,

一般情況下this對象指向調(diào)用函數(shù)的對象,全局環(huán)境中執(zhí)行函數(shù)this對象指向Window

call和apply函數(shù)中this指向指定的對象,如果指定的對為undefined或者null,那么this對象指向Window

在箭頭函數(shù)中,this對象等同于外層代碼塊的this

然后依然是每次都一樣的結(jié)尾,如果內(nèi)容有錯誤的地方歡迎指出;如果對你有幫助,歡迎點贊和收藏,轉(zhuǎn)載請征得同意后著明出處,如果有問題也歡迎私信交流,主頁添加了郵箱地址~溜了

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90657.html

相關(guān)文章

  • JS高級入門教程

    摘要:解析首先簡稱是由歐洲計算機制造商協(xié)會制定的標(biāo)準(zhǔn)化腳本程序設(shè)計語言。級在年月份成為的提議,由核心與兩個模塊組成。通過引入統(tǒng)一方式載入和保存文檔和文檔驗證方法對進行進一步擴展。其中表示的標(biāo)記位正好是低三位都是。但提案被拒絕了。 JS高級入門教程 目錄 本文章定位及介紹 JavaScript與ECMAScript的關(guān)系 DOM的本質(zhì)及DOM級介紹 JS代碼特性 基本類型與引用類型 JS的垃...

    zsy888 評論0 收藏0
  • 淺談細(xì)說 JS 函數(shù)(call,apply,重載)

    摘要:什么是函數(shù)引用的原話函數(shù)是一組可以隨時隨地運行的語句。函數(shù)是由這樣的方式進行聲明的關(guān)鍵字函數(shù)名一組參數(shù),以及置于括號中的待執(zhí)行代碼。 什么是函數(shù)? 引用 W3School 的原話: 函數(shù)是一組可以隨時隨地運行的語句。 函數(shù)是 ECMAScript 的核心。 函數(shù)是由這樣的方式進行聲明的:關(guān)鍵字 function、函數(shù)名、一組參數(shù),以及置于括號中的待執(zhí)行代碼。 函數(shù)的基本語法是這樣的:...

    U2FsdGVkX1x 評論0 收藏0
  • ECMA_作用域深入&This關(guān)鍵字

    摘要:預(yù)解析聲明告知瀏覽器在全局作用域中有一個變量名為的變量。執(zhí)行代碼的就是棧內(nèi)存,作用域也是棧內(nèi)存。關(guān)鍵字在中主要研究都是函數(shù)中的中的代表的是當(dāng)前行為執(zhí)行的主體方法,函數(shù),事件中的上下文代表的是當(dāng)前行為執(zhí)行的環(huán)境區(qū)域例如小明在沙縣小吃吃蛋炒飯。 基本認(rèn)識 數(shù)據(jù)類型 基本數(shù)據(jù)類型 string, number, null, boolean, undefined 引用數(shù)據(jù)類型 object: ...

    Harriet666 評論0 收藏0
  • FE.SRC-webpack原理梳理

    摘要:執(zhí)行完成后會返回如下圖的結(jié)果,根據(jù)返回數(shù)據(jù)把源碼和存儲在的屬性上的回調(diào)函數(shù)中調(diào)用類生成,并根據(jù)生成依賴后回調(diào)方法返回類。 webpack設(shè)計模式 一切資源皆Module Module(模塊)是webpack的中的關(guān)鍵實體。Webpack 會從配置的 Entry 開始遞歸找出所有依賴的模塊. 通過Loaders(模塊轉(zhuǎn)換器),用于把模塊原內(nèi)容按照需求轉(zhuǎn)換成新模塊內(nèi)容. 事件驅(qū)動架構(gòu) we...

    cfanr 評論0 收藏0
  • js中的Java式繼承

    摘要:中有三種不同的對象,三種對象的屬性和行為和下方的類似構(gòu)造函數(shù)對象構(gòu)造函數(shù)為的類定義名稱,任何添加到這個構(gòu)造函數(shù)對象中的屬性都是類字段和類方法。 JavaScript中的Java式繼承 區(qū)別 Java類似的強類型面向?qū)ο笳Z言,類為 實例字段 他們是基于實例的屬性或變量,用以保存獨立對象的狀態(tài) 實例方法 他們是類的所有實例所共享的方法,由每個獨立的實例調(diào)用 類字段 這些屬性或者變量是屬于類...

    SillyMonkey 評論0 收藏0
  • 全面解析JS中的this

    摘要:當(dāng)我們不想再對象內(nèi)部間接包含引用函數(shù),而像在某個對象上強制調(diào)用函數(shù)。我們可以用中內(nèi)置的和的方法來實現(xiàn),這兩個方法的第一個參數(shù)是一個對象,是給準(zhǔn)備的,接著再調(diào)用函數(shù)時將其綁定到。 this是什么 在javascript中,每個執(zhí)行上下文可以抽象成一組對象showImg(https://segmentfault.com/img/bVuKR7); 而this是與執(zhí)行上下文相關(guān)的特殊對象,任何...

    calx 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<