this

1. call, apply 有什么作用?有什么區(qū)別卒煞?

call和apply用來(lái)直接指定this的綁定對(duì)象痪宰;
區(qū)別是call直接傳入?yún)?shù),而apply傳入的是數(shù)組畔裕;

fn.call(context, p1, p2,...);
fn.apply(context, [p1,p2,...]);

代碼題:

1.以下代碼輸出是什么衣撬?
var john = {
    firstName: "John"
}

function func() {
    alert(this.firstName + ": hi!")
}
john.sayHi = func
john.sayHi()
  • 顯示彈窗:John:hi!
Paste_Image.png
2. 下面代碼輸出的是什么扮饶?為什么具练?
func()

function func() {
    alert(this)
}
//window
  • 返回window對(duì)象;因?yàn)椋?/li>
  • 聲明提前甜无,func()執(zhí)行命令alert(this);
  • func()運(yùn)行在全局作用域window下扛点,故this指向window
3. 下面代碼輸出什么?
function fn0() {
    function fn() {
        console.log(this);
    }
    fn();
}

fn0();


document.addEventListener('click', function(e) {
    console.log(this);
    setTimeout(function() {
        console.log(this);
    }, 200);
}, false);
// window
// document
// window
  • fn0中的this指向全局作用域岂丘;
  • document.addEventListener中的this指向document;
  • setTimeout中的this指向全局作用域陵究。
4. 下面代碼輸出什么?為什么奥帘?
var john = {
    firstName: "John"
}

function func() {
    alert(this.firstName)
}
func.call(john)
  • 彈窗John
  • func.call(john)使得func中this指向john
5. 下面代碼輸出什么铜邮,為什么?
var john = {
    firstName: "John",
    surname: "Smith"
}

function func(a, b) {
    alert(this[a] + ' ' + this[b])
}
func.call(john, 'firstName', 'surname')
  • 彈窗:John Smith
Paste_Image.png
  • 通過(guò)call方法將function中的this指向john
6. 以下代碼有什么問(wèn)題?如何修改松蒜?
var module = {
    bind: function() {
        $btn.on('click', function() {
            console.log(this) //this指什么
            this.showMsg();
        })
    },

    showMsg: function() {
        console.log('饑人谷');
    }
}
  • 事件綁定的回調(diào)函數(shù)中第一個(gè)this指向$btn扔茅,第二個(gè)應(yīng)該指向module,故需聲明一個(gè)變量給this賦值秸苗,如下:
var module = {
    var _this = this;
    bind: function() {
        $btn.on('click', function() {
            console.log(this) //this指什么
            _this.showMsg();
        })
    },

    showMsg: function() {
        console.log('饑人谷');
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末召娜,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子难述,更是在濱河造成了極大的恐慌萤晴,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胁后,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡嗦枢,警方通過(guò)查閱死者的電腦和手機(jī)攀芯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)文虏,“玉大人侣诺,你說(shuō)我怎么就攤上這事⊙趺兀” “怎么了年鸳?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,723評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)丸相。 經(jīng)常有香客問(wèn)我搔确,道長(zhǎng),這世上最難降的妖魔是什么灭忠? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,357評(píng)論 1 283
  • 正文 為了忘掉前任膳算,我火速辦了婚禮,結(jié)果婚禮上弛作,老公的妹妹穿的比我還像新娘涕蜂。我一直安慰自己,他們只是感情好映琳,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布机隙。 她就那樣靜靜地躺著,像睡著了一般萨西。 火紅的嫁衣襯著肌膚如雪有鹿。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,760評(píng)論 1 289
  • 那天原杂,我揣著相機(jī)與錄音印颤,去河邊找鬼。 笑死穿肄,一個(gè)胖子當(dāng)著我的面吹牛年局,可吹牛的內(nèi)容都是我干的际看。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼矢否,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼仲闽!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起僵朗,我...
    開(kāi)封第一講書(shū)人閱讀 37,672評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤赖欣,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后验庙,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體顶吮,經(jīng)...
    沈念sama閱讀 44,118評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評(píng)論 2 325
  • 正文 我和宋清朗相戀三年粪薛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了悴了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,599評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡违寿,死狀恐怖湃交,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情藤巢,我是刑警寧澤搞莺,帶...
    沈念sama閱讀 34,264評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站掂咒,受9級(jí)特大地震影響才沧,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜俏扩,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評(píng)論 3 312
  • 文/蒙蒙 一糜工、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧录淡,春花似錦捌木、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,731評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至彬檀,卻和暖如春帆啃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背窍帝。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,956評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工努潘, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,286評(píng)論 2 360
  • 正文 我出身青樓疯坤,卻偏偏與公主長(zhǎng)得像报慕,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子压怠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評(píng)論 2 348

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

  • 簡(jiǎn)答題 1.apply眠冈、call 有什么作用,什么區(qū)別 call apply菌瘫,調(diào)用一個(gè)函數(shù)蜗顽,傳入函數(shù)執(zhí)行上下文及參...
    GarenWang閱讀 545評(píng)論 1 4
  • 一、this 相關(guān)問(wèn)題 知乎上關(guān)于this的解答 this 的值到底是什么雨让?一次說(shuō)清楚 this 的工作原理在js...
    66dong66閱讀 548評(píng)論 0 0
  • apply雇盖、call 有什么作用,什么區(qū)別 首先要引入this這個(gè)概念由于運(yùn)行期綁定的特性栖忠,this的含義非常多刊懈,...
    塊壘閱讀 194評(píng)論 0 0
  • 新手在入門(mén) JavaScript 的過(guò)程中,一定會(huì)踩很多關(guān)于 this 的坑娃闲,出現(xiàn)問(wèn)題的本質(zhì)就是 this 指針的...
    一縷殤流化隱半邊冰霜閱讀 3,793評(píng)論 15 47
  • 1. apply、call 匾浪、bind有什么作用皇帮,什么區(qū)別? call ,apply的作用:調(diào)用一個(gè)函數(shù)蛋辈,傳入函數(shù)...
    Rising_suns閱讀 390評(píng)論 0 0