深入理解this的理解和用法

什么是this扶欣?

JavaScript中函數(shù)的this對(duì)象是函數(shù)在執(zhí)行時(shí)所處的作用域仗考,是關(guān)鍵字音同,它比較靈活,只有在執(zhí)行的時(shí)候知道它指向了誰秃嗜!

5種指向

1权均,指向 window對(duì)象即全局對(duì)象
在全局作用域下,this指向全局對(duì)象锅锨。在瀏覽器中全局對(duì)象就是window對(duì)象

function test(){
 console.log(this);
}
test();  //window

2叽赊,指向最近的對(duì)象或聲明的對(duì)象
當(dāng)this關(guān)鍵字在一個(gè)聲明對(duì)象內(nèi)部使用,其值會(huì)被綁定到調(diào)用該this的函數(shù)的最近的父對(duì)象

var person = {
 first: 'John',
 last: 'Smith',
 full: function() {
  console.log(this.first + ' ' + this.last);
 },
 personTwo: {
  first: 'Allison',
  last: 'Jones',
  full: function() {
   console.log(this.first + ' ' + this.last);
  }
 }
};
person.full(); // John Smith
person.personTwo.full(); // Allison Jones

3必搞,new 實(shí)例化時(shí)指向?qū)嵗瘜?duì)象
當(dāng)使用new關(guān)鍵字構(gòu)建一個(gè)新的對(duì)象必指,this會(huì)綁定到這個(gè)新對(duì)象

function Animal(name){
    this.name = name;
    console.log(this.name);
}
var cat = new Animal('cat');

4,call/apply/bind指向第一個(gè)參數(shù)對(duì)象

function add(c, d) {
 console.log(this.a + this.b + c + d);
}
add(3,4); // 
// 延伸一下
a + b + 2 // error  a/b 未定義 會(huì)報(bào)錯(cuò)
//this.a + this.b + 2 // NaN 恕洲,undefined 則不會(huì)報(bào)錯(cuò)
//說明 undefined + 2 == NaN
var  ten = {a: 1, b: 2}
add.call(ten, 3, 4) //10
add.apply(ten, [3, 4]) //10
// bind 場景
var small = {
 a: 1,
 go: function(b,c,d){
  console.log(this.a+b+c+d);
 }
}
var large = {
 a: 100
}
var bindTest = small.go.bind(large, 1, 2, 3)
bindTest()
// 還有一種寫法
var bindTest = small.go.bind(large, 1) //已知部分參數(shù)
bindTest(2, 3) //剩余參數(shù)追加
small.go.bind(large, 1)(2,3)

5塔橡,es6中箭頭函數(shù)中的this對(duì)象
定義到對(duì)象屬性方法中,指向window
定義在原型鏈上的this霜第,指向window
定義在構(gòu)造函數(shù)中葛家,會(huì)報(bào)錯(cuò)
定義在事件函數(shù)中,指向window

let names = 'window-names'
const obj = {
   name: 'es6',
    say: () => {
        console.log(this === window)
        console.log(this.names)  
    }
}
obj.say() //true
// 原型鏈上
 Cat.prototype.sayName = () => {
    console.log(this === window)
    return this.name
  }
  const cat = new Cat('mm');
  cat.sayName()
  // true     this為window
  // ""  window.name 為空 

  // 解決方法 ===> sayName 更改成普通函數(shù)  
  
  function Cat(name) {
    this.name = name;
  } 
  Cat.prototype.sayName = function () {
    console.log(this === ff)
    return this.name
  }
  const ff = new Cat('ff');
  ff.sayName();
// 事件函數(shù) 箭頭函數(shù)在聲明的時(shí)候就綁定了它的上下文環(huán)境泌类,要?jiǎng)討B(tài)改變上下文是不可能的癞谒。
const button = document.getElementById('mngb');
  button.addEventListener('click', ()=> {
    console.log(this === window) // true
    this.innerHTML = 'clicked button'
  })
  // 其實(shí)我們是要this執(zhí)行被點(diǎn)擊的button
  // 解決方法 --> 回調(diào)函數(shù)用普通函數(shù)
  const button = document.getElementById('mngb');
  button.addEventListener('click', function(e){
    console.log(this === button)
    console.log(e.target)
    this.innerHTML = 'clicked button'
  })
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子扯俱,更是在濱河造成了極大的恐慌书蚪,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,743評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件迅栅,死亡現(xiàn)場離奇詭異殊校,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)读存,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門为流,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人让簿,你說我怎么就攤上這事敬察。” “怎么了尔当?”我有些...
    開封第一講書人閱讀 157,285評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵莲祸,是天一觀的道長。 經(jīng)常有香客問我椭迎,道長锐帜,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,485評(píng)論 1 283
  • 正文 為了忘掉前任畜号,我火速辦了婚禮缴阎,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘简软。我一直安慰自己蛮拔,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,581評(píng)論 6 386
  • 文/花漫 我一把揭開白布痹升。 她就那樣靜靜地躺著建炫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪视卢。 梳的紋絲不亂的頭發(fā)上踱卵,一...
    開封第一講書人閱讀 49,821評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音据过,去河邊找鬼惋砂。 笑死,一個(gè)胖子當(dāng)著我的面吹牛绳锅,可吹牛的內(nèi)容都是我干的西饵。 我是一名探鬼主播,決...
    沈念sama閱讀 38,960評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼鳞芙,長吁一口氣:“原來是場噩夢啊……” “哼眷柔!你這毒婦竟也來了期虾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,719評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤驯嘱,失蹤者是張志新(化名)和其女友劉穎镶苞,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鞠评,經(jīng)...
    沈念sama閱讀 44,186評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡茂蚓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,516評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了剃幌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片聋涨。...
    茶點(diǎn)故事閱讀 38,650評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖负乡,靈堂內(nèi)的尸體忽然破棺而出牍白,到底是詐尸還是另有隱情,我是刑警寧澤抖棘,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布茂腥,位于F島的核電站,受9級(jí)特大地震影響切省,放射性物質(zhì)發(fā)生泄漏础芍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,936評(píng)論 3 313
  • 文/蒙蒙 一数尿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧惶楼,春花似錦右蹦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至豹储,卻和暖如春贷盲,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背剥扣。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評(píng)論 1 266
  • 我被黑心中介騙來泰國打工巩剖, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人钠怯。 一個(gè)月前我還...
    沈念sama閱讀 46,370評(píng)論 2 360
  • 正文 我出身青樓佳魔,卻偏偏與公主長得像,于是被迫代替她去往敵國和親晦炊。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鞠鲜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,527評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容