this-Assignment

問答

  • apply萨赁、call 有什么作用绑榴,什么區(qū)別

1.function.prototype.call()

函數(shù)實例的call方法可以指定函數(shù)內部this的指向深寥,即函數(shù)執(zhí)行時所在的作用域

var obj = {};
var fn = function(){
  return this
}
fn()  === this // true
fn.call(obj) === obj // true

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

fn.call(null) === this
fn.call(undefined)  === this
fn.call === this 

call方法內部的參數(shù)如果為空健提、null和undefined,則默認傳入全局對象伟叛。

var obj = {};
var add = function(x,y){ 
return x+y
}

add.call(obj,2,3)

call方法還可以接受多個參數(shù)私痹。call的第一個參數(shù)就是this所要指向的那個對象,后面的參數(shù)則是函數(shù)調用時所需的參數(shù)统刮。

2.function.prototype.apply()
apply方法的作用與call方法類似紊遵,也是改變this指向,然后再調用該函數(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ù)。

代碼

1.以下代碼輸出什么?
Johb:hi!
2.下面代碼輸出什么醋旦,為什么
[object Window]
因為該函數(shù)的執(zhí)行環(huán)境是全局環(huán)境window
3.下面代碼輸出什么
window對象//調用函數(shù)fn時的全局環(huán)境是在window下

文檔對象//點擊文檔時執(zhí)行回調函數(shù)恒水,此時回調函數(shù)的執(zhí)行環(huán)境是文檔對象

window對象//點擊文檔后過0.2秒后,此時回調函數(shù)的執(zhí)行環(huán)境已經(jīng)變?yōu)槿汁h(huán)境
4.下面代碼輸出什么饲齐,why
John
函數(shù)實例func調用call方法钉凌,使其執(zhí)行環(huán)境在對象john下.
所以,函數(shù)func內部的this指向john對象
5.代碼輸出捂人?
John Smith

6.以下代碼有什么問題御雕,如何修改
var module= {
 bind: function(){ 
    $btn.on('click', function(){ 
      var that =this
      console.log(this) 
      //this指的是$btn
        that.showMsg()
      } ) 
    }, 
    showMsg: function(){ 
    console.log('饑人谷'); 
  }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市滥搭,隨后出現(xiàn)的幾起案子酸纲,更是在濱河造成了極大的恐慌,老刑警劉巖瑟匆,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件闽坡,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機疾嗅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進店門外厂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人代承,你說我怎么就攤上這事汁蝶。” “怎么了论悴?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵捧毛,是天一觀的道長幽勒。 經(jīng)常有香客問我湿颅,道長吠冤,這世上最難降的妖魔是什么样眠? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任傅是,我火速辦了婚禮摄欲,結果婚禮上挣输,老公的妹妹穿的比我還像新娘齐饮。我一直安慰自己捐寥,他們只是感情好,可當我...
    茶點故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布祖驱。 她就那樣靜靜地躺著握恳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪捺僻。 梳的紋絲不亂的頭發(fā)上乡洼,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天,我揣著相機與錄音匕坯,去河邊找鬼束昵。 笑死,一個胖子當著我的面吹牛葛峻,可吹牛的內容都是我干的锹雏。 我是一名探鬼主播,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼术奖,長吁一口氣:“原來是場噩夢啊……” “哼礁遵!你這毒婦竟也來了?” 一聲冷哼從身側響起采记,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤佣耐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后挺庞,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體晰赞,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了掖鱼。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片然走。...
    茶點故事閱讀 40,505評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖戏挡,靈堂內的尸體忽然破棺而出芍瑞,到底是詐尸還是另有隱情,我是刑警寧澤褐墅,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布拆檬,位于F島的核電站,受9級特大地震影響妥凳,放射性物質發(fā)生泄漏竟贯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一逝钥、第九天 我趴在偏房一處隱蔽的房頂上張望屑那。 院中可真熱鬧,春花似錦艘款、人聲如沸持际。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蜘欲。三九已至,卻和暖如春晌柬,著一層夾襖步出監(jiān)牢的瞬間姥份,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工空繁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留殿衰,地道東北人。 一個月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓盛泡,卻偏偏與公主長得像闷祥,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子傲诵,可洞房花燭夜當晚...
    茶點故事閱讀 45,515評論 2 359

推薦閱讀更多精彩內容