javascript中的this

var name = "Bob";
var nameObj ={
    name : "Tom",
    showName : function(){
        alert(this.name);
    },
    waitShowName : function(){
        setTimeout(this.showName, 1000);
        setTimeout(function(){
            nameObj.showName()
        }, 1000);
  }
};
nameObj.waitShowName();

一般而言翘骂,在Javascript中肿嘲,this指向函數(shù)執(zhí)行時的當(dāng)前對象

The this keyword is relative to the execution context, not the declaration context.

  • 當(dāng)沒有明確的執(zhí)行時的當(dāng)前對象時跃闹,this指向全局對象window惠猿。
            var obj = {
                 bar: "bar",
                 foo: function(){
                     console.log(this);
                 }
             };
             obj.foo();
             var bar = obj.foo;
             bar()
  • 在瀏覽器中setTimeout、setInterval和匿名函數(shù)執(zhí)行時的當(dāng)前對象通常是是全局對象window魄幕,當(dāng)然也有例外


    foo(function (){
        console.log(this)
    });


    function foo(fn){
            fn.call({});
        }

    //el.addEventListener('click', bar, false);

*eval函數(shù) 指向當(dāng)前執(zhí)行環(huán)境

var name = "window";

var Bob = {
    name: "Bob",
    showName: function(){
        eval("alert(this.name)");
    }
};

Bob.showName();    //Bob

當(dāng)然還有很多很多例子相艇,
涉及 new 還有es5中的 call,apply,bind, 以及es6中的() => {} lambda
有趣的例子(λx.x*x)(λx.x+2) js可以寫成 (x => x + 2)((x => x * x)(2))
不一一列舉了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末纯陨,一起剝皮案震驚了整個濱河市坛芽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌翼抠,老刑警劉巖咙轩,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異机久,居然都是意外死亡臭墨,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進店門膘盖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來胧弛,“玉大人,你說我怎么就攤上這事侠畔〗岣浚” “怎么了?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵软棺,是天一觀的道長红竭。 經(jīng)常有香客問我,道長喘落,這世上最難降的妖魔是什么茵宪? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮瘦棋,結(jié)果婚禮上稀火,老公的妹妹穿的比我還像新娘。我一直安慰自己赌朋,他們只是感情好凰狞,可當(dāng)我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布篇裁。 她就那樣靜靜地躺著,像睡著了一般赡若。 火紅的嫁衣襯著肌膚如雪达布。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天逾冬,我揣著相機與錄音黍聂,去河邊找鬼。 笑死粉渠,一個胖子當(dāng)著我的面吹牛分冈,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播霸株,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼雕沉,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了去件?” 一聲冷哼從身側(cè)響起坡椒,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎尤溜,沒想到半個月后倔叼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡宫莱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年丈攒,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片授霸。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡巡验,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出碘耳,到底是詐尸還是另有隱情显设,我是刑警寧澤,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布辛辨,位于F島的核電站捕捂,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏斗搞。R本人自食惡果不足惜指攒,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望僻焚。 院中可真熱鬧允悦,春花似錦、人聲如沸溅呢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽咐旧。三九已至驶鹉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間铣墨,已是汗流浹背室埋。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留伊约,地道東北人姚淆。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像屡律,于是被迫代替她去往敵國和親腌逢。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,762評論 2 345

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

  • Javascript 中的 this超埋,有時候讓人迷惑搏讶,所以總結(jié)了一下關(guān)于this指向的問題。 在函數(shù)中 this ...
    lxt410725閱讀 460評論 0 1
  • 1.函數(shù)調(diào)用棧和調(diào)用位置 在函數(shù)執(zhí)行的時候霍殴,會有一個活動記錄(也叫執(zhí)行上下文)來記錄函數(shù)的調(diào)用順序媒惕,這個就是函數(shù)調(diào)...
    lightNate閱讀 517評論 1 14
  • this this是javascript的一個關(guān)鍵字,隨著函數(shù)使用場合不同来庭,this的值會發(fā)生變化妒蔚。但是總有一個原...
    西瓜w閱讀 372評論 0 0
  • 本來不想寫this的東西,因為實在是頭暈啊月弛,講不清楚肴盏,JavaScript中的this真是讓人抓狂,好在我們調(diào)試的...
    轉(zhuǎn)角遇見一直熊閱讀 1,871評論 11 39
  • 原文:Understanding the "this" keyword in JavaScript 許多人被Jav...
    莫提時光閱讀 481評論 1 8