What's this?

一、apply有送、call 有什么作用胃榕,什么區(qū)別盛险?

1.二者都屬于function.prototype的一個方法,以另一個對象替換當(dāng)前對象勋又。
2.區(qū)別:

  • function.prototype.call()方法可以指定函數(shù)內(nèi)部this的指向,即函數(shù)執(zhí)行時所在的作用域苦掘。
var obj={};
var fn=function(){
   return this;
}
fn()===this; //true
fn.call(obj)===this; //false
fn.call(obj)===obj; //true

fn()執(zhí)行時所在的作用域是全局環(huán)境,所以this是window,而fn.call(obj)則是在對象obj環(huán)境下執(zhí)行的,所以此時的this指向obj。

  • funciton.prototype.apply()方法的作用與call方法類似楔壤,也是改變this指向鹤啡,然后再調(diào)用該函數(shù)。唯一的區(qū)別就是蹲嚣,它幾首一個數(shù)組作為函數(shù)執(zhí)行時的參數(shù)递瑰。
function fn(x,y){ 
    return x+y;
}
fn.call(null,1,1); //2
fn.apply(null,[1,1]); //2

fn函數(shù)本來接收兩個參數(shù),使用apply方法之后,就變成可以接收一個數(shù)組作為參數(shù)。

二隙畜、以下代碼輸出什么?

var john = { 
  firstName: "John" 
}
function func() { 
  alert(this.firstName + ": hi!")
}
john.sayHi = func
john.sayHi() 

結(jié)果:Johb:hi!

三抖部、下面代碼輸出什么,為什么议惰?

func();
function func() { 
  alert(this);
}

結(jié)果:[object Window]
原因:因為該函數(shù)是在全局環(huán)境window下執(zhí)行的慎颗。

四、下面代碼輸出什么

function fn0(){
    function fn(){
        console.log(this); //輸出的是window,因為this是在window下調(diào)用的
    }
    fn();
}
fn0();
document.addEventListener('click', function(e){
    console.log(this); //輸出的是document俯萎,因為這個是事件綁定傲宜,所以this指的是事件源DOM對象
    setTimeout(function(){
        console.log(this); //輸出的是window
    }, 200);
}, false);

五、下面代碼輸出什么夫啊,why函卒?

var john = { 
  firstName: "John" 
}

function func() { 
  alert( this.firstName )
}
func.call(john)

結(jié)果:John
原因:函數(shù)實例func調(diào)用的call方法,使其執(zhí)行環(huán)境在對象john下撇眯。所以函數(shù)func內(nèi)部的this指向john對象报嵌。

六、代碼輸出叛本?

var john = { 
  firstName: "John",
  surname: "Smith"
}

function func(a, b) { 
  alert( this[a] + ' ' + this[b] ) 
}
func.call(john, 'firstName', 'surname') 

結(jié)果:John Smith

七沪蓬、以下代碼有什么問題,如何修改来候?

var module= {
  bind: function(){
    $btn.on('click', function(){
      console.log(this) //this指什么? 輸出的是&btn的dom對象
      this.showMsg();  //報錯,因為這里的this指向的還是&btn的dom對象,在dom對象中找不到showMsg(),所以報錯
    })
  },
  
  showMsg: function(){
    console.log('饑人谷');
  }
}

修改方法:

<body>
    <button class="btn">點擊</button>
    <script>
        var $btn=$(".btn");
        var module={
            bind:function(){
                $btn.on("click",function(){
                    console.log(this);
                    module.showMsg();
                })
            },
            showMsg:function(){
                console.log("饑人谷");
            }
        }
        module.bind();
    </script>
</body>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末跷叉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子营搅,更是在濱河造成了極大的恐慌云挟,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件转质,死亡現(xiàn)場離奇詭異园欣,居然都是意外死亡,警方通過查閱死者的電腦和手機休蟹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門沸枯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人赂弓,你說我怎么就攤上這事绑榴。” “怎么了盈魁?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵翔怎,是天一觀的道長。 經(jīng)常有香客問我杨耙,道長赤套,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任珊膜,我火速辦了婚禮容握,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘车柠。我一直安慰自己唯沮,他們只是感情好脖旱,可當(dāng)我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布堪遂。 她就那樣靜靜地躺著介蛉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪溶褪。 梳的紋絲不亂的頭發(fā)上币旧,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天,我揣著相機與錄音猿妈,去河邊找鬼吹菱。 笑死,一個胖子當(dāng)著我的面吹牛彭则,可吹牛的內(nèi)容都是我干的鳍刷。 我是一名探鬼主播,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼俯抖,長吁一口氣:“原來是場噩夢啊……” “哼输瓜!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起芬萍,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤尤揣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后柬祠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體北戏,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年漫蛔,在試婚紗的時候發(fā)現(xiàn)自己被綠了嗜愈。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡莽龟,死狀恐怖蠕嫁,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情轧房,我是刑警寧澤拌阴,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站奶镶,受9級特大地震影響迟赃,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜厂镇,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一纤壁、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧捺信,春花似錦酌媒、人聲如沸欠痴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽喇辽。三九已至,卻和暖如春雨席,著一層夾襖步出監(jiān)牢的瞬間菩咨,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工陡厘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留抽米,地道東北人。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓糙置,卻偏偏與公主長得像云茸,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子谤饭,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,955評論 2 355

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

  • 工廠模式類似于現(xiàn)實生活中的工廠可以產(chǎn)生大量相似的商品标捺,去做同樣的事情,實現(xiàn)同樣的效果;這時候需要使用工廠模式网持。簡單...
    舟漁行舟閱讀 7,763評論 2 17
  • 目錄1.this究竟是什么2.綁定this的方法3.caller宜岛、arguments和callee 1.this究...
    犯迷糊的小羊閱讀 642評論 0 0
  • 單例模式 適用場景:可能會在場景中使用到對象,但只有一個實例功舀,加載時并不主動創(chuàng)建萍倡,需要時才創(chuàng)建 最常見的單例模式,...
    Obeing閱讀 2,073評論 1 10
  • 問答 1辟汰、apply列敲、call 有什么作用,什么區(qū)別 apply和call的作用:都是為了改變函數(shù)內(nèi)部的this指...
    StarLikeRain閱讀 389評論 0 0
  • 三帖汞、閉包和高階函數(shù) 3.1 閉包 3.1.1 變量的作用域 所謂變量的作用域戴而,就是變量的有效范圍。通過作用域的劃分...
    梁同學(xué)de自言自語閱讀 1,454評論 0 6