成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

javascript基礎(chǔ):this關(guān)鍵字

LeoHsiun / 1727人閱讀

摘要:它代表函數(shù)運(yùn)行時(shí),自動(dòng)生成的一個(gè)內(nèi)部對(duì)象,只能在函數(shù)內(nèi)部使用類似的還有。總結(jié)關(guān)鍵字就是,誰調(diào)用我,我就指向誰。注意由于已經(jīng)被定義為函數(shù)內(nèi)的一個(gè)變量。因此通過關(guān)鍵字定義或者將聲明為一個(gè)形式參數(shù),都將導(dǎo)致原生的不會(huì)被創(chuàng)建。

題目

封裝函數(shù) f,使 f 的 this 指向指定的對(duì)象 。

輸入例子
bindThis(function(a, b) {
    return this.test + a + b;
}, {test: 1})(2, 3);
輸出例子
6
分析 題目拆解

該題目的要求是:封裝一個(gè)函數(shù)bindThis,該函數(shù)有兩個(gè)參數(shù),第一個(gè)參數(shù)是一個(gè)內(nèi)部有使用this指針的函數(shù)f,第二個(gè)參數(shù)是一個(gè)對(duì)象obj,執(zhí)行bindThis之后,返回一個(gè)函數(shù),該函數(shù)里面的this就被綁定到obj上面。。。好吧,我承認(rèn)我剛看到這個(gè)時(shí),也很暈,但是如果我把它寫成下面的樣子,是不是就感覺好多了呢?

function f(a, b) {
    return this.test + a + b;
}

function bindThis(f, obj) {
    //你實(shí)現(xiàn)的部分
}

//執(zhí)行函數(shù)
var a = bindThis(f,{test:1});
a(2,3);
什么是this

this是Javascript語言的一個(gè)關(guān)鍵字。它代表函數(shù)運(yùn)行時(shí),自動(dòng)生成的一個(gè)內(nèi)部對(duì)象,只能在函數(shù)內(nèi)部使用(類似的還有arguments)。具體的大家可以看看阮一峰的Javascript的this用法
和變量不同,關(guān)鍵字this沒有作用域的限制,嵌套的函數(shù)不會(huì)從調(diào)用它的函數(shù)中繼承this。
簡(jiǎn)單的將this的指向分為四種情況:

函數(shù)調(diào)用

這是函數(shù)的最通常用法,屬于全局性調(diào)用,其this的值不是全局對(duì)象Global(非嚴(yán)格模式下)就是undefined(嚴(yán)格模式下)。

對(duì)象方法調(diào)用

函數(shù)還可以作為某個(gè)對(duì)象的方法調(diào)用,這時(shí)this就指這個(gè)上級(jí)對(duì)象.

構(gòu)造函數(shù)調(diào)用

所謂構(gòu)造函數(shù),就是通過這個(gè)函數(shù)生成一個(gè)新對(duì)象(object)。這時(shí),this就指這個(gè)新對(duì)象。

bind apply call

apply()是函數(shù)對(duì)象的一個(gè)方法,它的作用是改變函數(shù)的調(diào)用對(duì)象,它的第一個(gè)參數(shù)就表示改變后的調(diào)用這個(gè)函數(shù)的對(duì)象。因此,this指的就是這第一個(gè)參數(shù)。bind,call類似。

總結(jié):this關(guān)鍵字就是,誰調(diào)用我,我就指向誰。

解決方法

首先,看到this的綁定這幾個(gè)字,你是不想條件反射的想起了javascript的三劍客:bind apply call?

bind apply call的區(qū)別

call 和 apply 都是為了改變某個(gè)函數(shù)運(yùn)行時(shí)的 context 即上下文而存在的,換句話說,就是為了改變函數(shù)體內(nèi)部 this 的指向。因?yàn)?JavaScript 的函數(shù)存在「定義時(shí)上下文」和「運(yùn)行時(shí)上下文」以及「上下文是可以改變的」這樣的概念。

相同點(diǎn):

都可以為函數(shù)綁定this。

不同點(diǎn):

call和apply基本的區(qū)別:參數(shù)不同。apply() 接收兩個(gè)參數(shù),第一個(gè)是綁定 this 的值,第二個(gè)是一個(gè)參數(shù)數(shù)組。而 call() 呢,它的第一個(gè)參數(shù)也是綁定給 this 的值,但是后面接受的是不定參數(shù),而不再是一個(gè)數(shù)組,也就是說你可以像平時(shí)給函數(shù)傳參那樣把這些參數(shù)一個(gè)一個(gè)傳遞。

bind的區(qū)別:創(chuàng)建一個(gè)新的函數(shù)。具體的可以看看這篇文章理解 Javascript 的 Function.prototype.bind

解決方法一:使用bind()

下面的例子是其中一個(gè)解決方法,同時(shí)也說明了bind()方法是創(chuàng)建了一個(gè)新的函數(shù)。

function f(a, b) {
    return this.test + a + b;
}

function bindThis(f, obj) {
    //你實(shí)現(xiàn)的部分
    return f.bind(obj);
}

//執(zhí)行函數(shù)
var a = bindThis(f,{test:1});
console.log(a(2,3));
console.log(f(2,3));

輸出結(jié)果

6
NaN
解決方法二:使用apply()
function bindThis(f, obj) {
    //你實(shí)現(xiàn)的部分
    return function () {
        return f.apply(obj, arguments);
    };
}

這里使用一個(gè)函數(shù)包裝了一下apply方法,然后返回該函數(shù)。

arguments是JavaScript 中每個(gè)函數(shù)內(nèi)都能訪問一個(gè)特別變量 arguments。這個(gè)變量維護(hù)著所有傳遞到這個(gè)函數(shù)中的參數(shù)列表。

注意: 由于 arguments 已經(jīng)被定義為函數(shù)內(nèi)的一個(gè)變量。 因此通過 var 關(guān)鍵字定義 arguments 或者將 arguments 聲明為一個(gè)形式參數(shù), 都將導(dǎo)致原生的 arguments 不會(huì)被創(chuàng)建。

arguments 變量不是一個(gè)數(shù)組(Array)。 盡管在語法上它有數(shù)組相關(guān)的屬性 length,但它不從 Array.prototype 繼承,實(shí)際上它是一個(gè)對(duì)象(Object)。

解決方法三:使用call()

和apply()類似,僅參數(shù)的傳入方式不同。

function bindThis(f, obj) {
    //你實(shí)現(xiàn)的部分
    return function (a,b) {
        return f.call(obj, a,b);
    };
}
總結(jié)

該題目主要考察的是this關(guān)鍵字及改變this指向的方法,再下才疏學(xué)淺,只能找到這幾個(gè)方法了,但是鑒于javascript這門語言的靈活性,我老感覺應(yīng)該是還有其他的方法的,希望各位知道了能夠不吝賜教。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/79474.html

相關(guān)文章

  • JavaScript基礎(chǔ)心法——this

    摘要:原文地址基礎(chǔ)心法歡迎。作為一個(gè)構(gòu)造函數(shù)被綁定到正在構(gòu)造的新對(duì)象。通過構(gòu)造函數(shù)創(chuàng)建一個(gè)對(duì)象其實(shí)執(zhí)行這樣幾個(gè)步驟創(chuàng)建新對(duì)象將指向這個(gè)對(duì)象給對(duì)象賦值屬性方法返回所以就是指向創(chuàng)建的這個(gè)對(duì)象上。 原文地址:JavaScript基礎(chǔ)心法——this 歡迎star。 如果有錯(cuò)誤的地方歡迎指正。 看看這個(gè)有著深不可測(cè)的魔力的this到底是個(gè)什么玩意兒 ~ 什么是this 在傳統(tǒng)面向?qū)ο蟮恼Z言中,比如...

    hover_lew 評(píng)論0 收藏0
  • 快速掌握JavaScript面試基礎(chǔ)知識(shí)(二)

    摘要:第一部分請(qǐng)點(diǎn)擊快速掌握面試基礎(chǔ)知識(shí)一閉包閉包由一個(gè)函數(shù)以及該函數(shù)定義是所在的環(huán)境組成。當(dāng)匿名函數(shù)執(zhí)行的時(shí)候,的值為。這個(gè)問題可以改用后面會(huì)介紹方法來解決,通過對(duì)每一個(gè)匿名函數(shù)構(gòu)建獨(dú)立的外部作用域來實(shí)現(xiàn)。 譯者按: 總結(jié)了大量JavaScript基本知識(shí)點(diǎn),很有用! 原文: The Definitive JavaScript Handbook for your next develope...

    fyber 評(píng)論0 收藏0
  • 快速掌握JavaScript面試基礎(chǔ)知識(shí)(三)

    摘要:第一部分請(qǐng)點(diǎn)擊快速掌握面試基礎(chǔ)知識(shí)一關(guān)鍵字如果使用關(guān)鍵字來調(diào)用函數(shù)式很特別的形式。該對(duì)象默認(rèn)包含了指向原構(gòu)造函數(shù)的屬性。接下來通過例子來幫助理解屬性包含了構(gòu)造函數(shù)以及構(gòu)造函數(shù)中在上定義的屬性。也就是說,的回調(diào)函數(shù)后執(zhí)行。 譯者按: 總結(jié)了大量JavaScript基本知識(shí)點(diǎn),很有用! 原文: The Definitive JavaScript Handbook for your next...

    qieangel2013 評(píng)論0 收藏0
  • #yyds干貨盤點(diǎn)# 前端基礎(chǔ)知識(shí)面試集錦3

    摘要:當(dāng)解釋器尋找引用值時(shí),會(huì)首先檢索其在棧中的地址,取得地址后從堆中獲得實(shí)體如何實(shí)現(xiàn)繼承構(gòu)造繼承原型繼承實(shí)例繼承拷貝繼承原型機(jī)制或和方法去實(shí)現(xiàn)較簡(jiǎn)單,建議使用構(gòu)造函數(shù)與原型混合方式。它是基于的一個(gè)子集。 JavaScript介紹js的基本數(shù)據(jù)類型。Undefined、Null、Boolean、Number、Stri...

    番茄西紅柿 評(píng)論0 收藏2637
  • Javascript基礎(chǔ)知識(shí)(一)

    摘要:它可以接收兩個(gè)參數(shù),表示要查找的子字符串,表示查找的開始位置,省略的話則從開始位置進(jìn)行檢索。它會(huì)返回第一個(gè)匹配的子字符串的起始位置,如果沒有匹配的,則返回。返回一個(gè)布爾值,表示指定的對(duì)象是否在本對(duì)象的原型鏈中。 前言 前端開發(fā)最基本的就是HTML + CSS + JS了,剛?cè)胄袝r(shí)聽到的介紹就是,寫頁(yè)面亦如造房子,HTML為搭戶型,CSS是房屋裝飾,JS則好比是水電安裝,是最后的功能了。...

    MrZONT 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<