JS學習筆記之this指向

初學JS的朋友可能對this指向問題有些困惑昂拂。最近在看《Javascript設計模式與開發(fā)實踐》一書运授,里面總結得很到位咏尝。梳理下大致可以分為4情況,有興趣的可以自行去翻書閱讀褂傀。

作為對象的方法調(diào)用

作為普通函數(shù)調(diào)用

構造器調(diào)用

Function.prototype.call和Function.prototype.apply調(diào)用

1忍啤、作為對象的方法調(diào)用

當函數(shù)作為對象的方法被調(diào)用時,此時this指向該對象仙辟。

var obj = {
     name: lq,
     getName: function () {
        console.log (this === obj); // true
        console.log (this.name); // lq
     }
 }

2同波、作為普通函數(shù)調(diào)用

當函數(shù)不作為對象屬性被調(diào)用,而是通過普通的函數(shù)調(diào)用欺嗤,此時的this總是指向全局對象参萄。在瀏覽器環(huán)境的JavaScript里,就是window對象煎饼。

 window.name = 'lq';
 let getName = function () {
     return this.name;
 }
 console.log ( getName() ); // 輸出:lq 此時this指向window對象

又比如:

 window.name = 'lq';
 let myObj = {
     name: 'xiaoming',
     getName: function () {
         return this.name; 
     }
 };
 
 let getName = myObj.getName;
 console.log ( getName() ); // 輸出:lq 

有時候在我們點擊div節(jié)點的事件函數(shù)內(nèi)部讹挎,如果有一個callback回調(diào)函數(shù),當callback被當作普通函數(shù)調(diào)用時吆玖,callback內(nèi)部的this指向window,但實際上我們想讓它指向被點擊的div節(jié)點本身筒溃。代碼如下:

 <html>
    <body>
        <div id='div1'>my is div node</div>
    </body>
    <script>
        window.id = 'window';
        document.querySelector('#div1').onclick = function () {
            console.log (this.id); // 輸出:div1 
            let callback = function () {
                console.log (this.id); // 輸出:window
            }
            callback();
        }
    </script>
 </html>    
    

通常的解決方法是用一個變量來保存div節(jié)點的引用:

 document.querySelector('#div1').onclick = function () {
     let _this = this;
     let callback = function () {
         console.log (_this.id); //輸出:div1
     }
     callback();
 }

另外,在ESMAScript5下的strict嚴格模式下沾乘,這種普通函數(shù)調(diào)用已經(jīng)被規(guī)定為不會指向全局對象怜奖,而是undefined。

 function fun () {
     'use strict'
     console.log (this); //輸出了:undefined
 }
 fun();

3翅阵、構造器調(diào)用

Javascript種沒有類的概念歪玲,但提供了new運算符迁央,這樣我們可以從構造器中創(chuàng)建對象。除了宿主提供的一些內(nèi)置函數(shù)滥崩,大部分的Javascript函數(shù)可以當作構造器使用岖圈。構造器跟普通函數(shù)沒什么太大區(qū)別,唯一的區(qū)別是被調(diào)用的方式钙皮。

當用new運算符調(diào)用函數(shù)時蜂科,該函數(shù)會返回一個對象,一般情況下短条,構造器里的this都指向返回的這個對象导匣。如下:

 let myObj = function () {
     this.name = 'lq';
 };
 
 let obj = new myObj();
 console.log (obj.name); //輸出:lq

如果new構造器顯式地返回一個object類型的對象,那么運算的結果就會最終返回這個對象茸时,this就不是我們之前所期望的this了贡定。如下:

 let myObj = function () {
     this.name = 'lq';
     return {
        name: 'xiaoming';   
     }
 }
 let obj = new myObj();
 console.log(obj.name); // 輸出:xiaoming 

如果構造器返回的不是object類型的對象,而是一個非對象類型的數(shù)據(jù)屹蚊,就沒有上面的問題厕氨。

let myObj = function () {
    this.name = 'lq';
    return 'xiaoming';
};
let obj = new myObj();
console.log (obj.name); //輸出:lq

4、Function.prototype.call和Function.prototype.apply調(diào)用

這兩種方式調(diào)用可以動態(tài)地改變傳入函數(shù)的this:

 let obj1 = {
     name: 'lq',
     getName: function () {
         return this.name;
     }
 };
 let obj2 = {
     name: 'xiaoming'
 };
 console.log (obj1.getName()); //輸出:lq
 console.log (obj1.getName.call(obj2)); // 輸出:xiaoming
 console.log (obj1.getName.apply(obj2)); //輸出:xiaoming
 
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末汹粤,一起剝皮案震驚了整個濱河市命斧,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌嘱兼,老刑警劉巖国葬,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異芹壕,居然都是意外死亡汇四,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進店門踢涌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來通孽,“玉大人,你說我怎么就攤上這事睁壁”晨啵” “怎么了?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵潘明,是天一觀的道長行剂。 經(jīng)常有香客問我,道長钳降,這世上最難降的妖魔是什么厚宰? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮遂填,結果婚禮上铲觉,老公的妹妹穿的比我還像新娘澈蝙。我一直安慰自己,他們只是感情好撵幽,可當我...
    茶點故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布碉克。 她就那樣靜靜地躺著,像睡著了一般并齐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上客税,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天况褪,我揣著相機與錄音,去河邊找鬼更耻。 笑死测垛,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的秧均。 我是一名探鬼主播食侮,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼目胡!你這毒婦竟也來了锯七?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤誉己,失蹤者是張志新(化名)和其女友劉穎眉尸,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體巨双,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡噪猾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了筑累。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片袱蜡。...
    茶點故事閱讀 38,626評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖慢宗,靈堂內(nèi)的尸體忽然破棺而出坪蚁,到底是詐尸還是另有隱情,我是刑警寧澤婆廊,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布迅细,位于F島的核電站,受9級特大地震影響淘邻,放射性物質(zhì)發(fā)生泄漏茵典。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一宾舅、第九天 我趴在偏房一處隱蔽的房頂上張望统阿。 院中可真熱鬧彩倚,春花似錦、人聲如沸扶平。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽结澄。三九已至哥谷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間麻献,已是汗流浹背们妥。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留勉吻,地道東北人监婶。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像齿桃,于是被迫代替她去往敵國和親惑惶。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,494評論 2 348

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

  • 第2章 基本語法 2.1 概述 基本句法和變量 語句 JavaScript程序的執(zhí)行單位為行(line)短纵,也就是一...
    悟名先生閱讀 4,131評論 0 13
  • 函數(shù)和對象 1带污、函數(shù) 1.1 函數(shù)概述 函數(shù)對于任何一門語言來說都是核心的概念。通過函數(shù)可以封裝任意多條語句踩娘,而且...
    道無虛閱讀 4,543評論 0 5
  • 工廠模式類似于現(xiàn)實生活中的工廠可以產(chǎn)生大量相似的商品刮刑,去做同樣的事情,實現(xiàn)同樣的效果;這時候需要使用工廠模式养渴。簡單...
    舟漁行舟閱讀 7,724評論 2 17
  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持雷绢,譯者再次奉上一點點福利:阿里云產(chǎn)品券,享受所有官網(wǎng)優(yōu)惠理卑,并抽取幸運大...
    HetfieldJoe閱讀 2,991評論 4 14
  • 抓住9月的尾巴翘紊,更一發(fā)8月的空瓶。 熬著最貴的夜寫下的藐唠,不看的話帆疟,你的良心不會痛嗎~ 1. 麗得姿針劑補水面膜 可...
    BetterHana閱讀 385評論 0 2