JavaScript中的this關(guān)鍵字使用方法總結(jié)
在javascritp中,不一定只有對(duì)象方法的上下文中才有this, 全局函數(shù)調(diào)用和其他的幾種不同的上下文中也有this指代。
它可以是全局對(duì)象、當(dāng)前對(duì)象或者任意對(duì)象,這完全取決于函數(shù)的調(diào)用方式。JavaScript 中函數(shù)的調(diào)用有以下幾種方式:作為對(duì)象方法調(diào)用,作為函數(shù)調(diào)用,作為構(gòu)造函數(shù)調(diào)用,和使用 apply 或 call 調(diào)用。
1.作為對(duì)象方法調(diào)用
在 JavaScript 中,函數(shù)也是對(duì)象,因此函數(shù)可以作為一個(gè)對(duì)象的屬性,此時(shí)該函數(shù)被稱為該對(duì)象的方法,在使用這種調(diào)用方式時(shí),this 被自然綁定到該對(duì)象。
var point = {
x : 0,
y : 0,
moveTo : function(x, y) {
this.x = this.x + x;
this.y = this.y + y;
}
};
point.moveTo(1, 1)//this 綁定到當(dāng)前對(duì)象,即 point 對(duì)象
2.作為函數(shù)調(diào)用
函數(shù)也可以直接被調(diào)用,此時(shí) this 綁定到全局對(duì)象。在瀏覽器中,window 就是該全局對(duì)象。比如下面的例子:函數(shù)被調(diào)用時(shí),this 被綁定到全局對(duì)象,接下來執(zhí)行賦值語(yǔ)句,相當(dāng)于隱式的聲明了一個(gè)全局變量,這顯然不是調(diào)用者希望的。
function makeNoSense(x) {
this.x = x;
}
makeNoSense(5);
x;// x 已經(jīng)成為一個(gè)值為 5 的全局變量
對(duì)于內(nèi)部函數(shù),即聲明在另外一個(gè)函數(shù)體內(nèi)的函數(shù),這種綁定到全局對(duì)象的方式會(huì)產(chǎn)生另外一個(gè)問題。我們?nèi)匀灰郧懊嫣岬降?point 對(duì)象為例,這次我們希望在 moveTo 方法內(nèi)定義兩個(gè)函數(shù),分別將 x,y 坐標(biāo)進(jìn)行平移。結(jié)果可能出乎大家意料,不僅 point 對(duì)象沒有移動(dòng),反而多出兩個(gè)全局變量 x,y。
var point = {
x : 0,
y : 0,
moveTo : function(x, y) {
// 內(nèi)部函數(shù)
var moveX = function(x) {
this.x = x;//this 綁定到了哪里?
};
// 內(nèi)部函數(shù)
var moveY = function(y) {
this.y = y;//this 綁定到了哪里?
};
moveX(x);
moveY(y);
}
};
point.moveTo(1, 1);
point.x; //==>0
point.y; //==>0
x; //==>1
y; //==>1
這屬于 JavaScript 的設(shè)計(jì)缺陷,正確的設(shè)計(jì)方式是內(nèi)部函數(shù)的 this 應(yīng)該綁定到其外層函數(shù)對(duì)應(yīng)的對(duì)象上,為了規(guī)避這一設(shè)計(jì)缺陷,聰明的 JavaScript 程序員想出了變量替代的方法,約定俗成,該變量一般被命名為 that。
var point = {
x : 0,
y : 0,
moveTo : function(x, y) {
var that = this;
// 內(nèi)部函數(shù)
var moveX = function(x) {
that.x = x;
};
// 內(nèi)部函數(shù)
var moveY = function(y) {
that.y = y;
}
moveX(x);
moveY(y);
}
};
point.moveTo(1, 1);
point.x; //==>1
point.y; //==>1
作為構(gòu)造函數(shù)調(diào)用
JavaScript 支持面向?qū)ο笫骄幊?,與主流的面向?qū)ο笫骄幊陶Z(yǔ)言不同,JavaScript 并沒有類(class)的概念,而是使用基于原型(prototype)的繼承方式。相應(yīng)的,JavaScript 中的構(gòu)造函數(shù)也很特殊,如果不使用 new 調(diào)用,則和普通函數(shù)一樣。作為又一項(xiàng)約定俗成的準(zhǔn)則,構(gòu)造函數(shù)以大寫字母開頭,提醒調(diào)用者使用正確的方式調(diào)用。如果調(diào)用正確,this 綁定到新創(chuàng)建的對(duì)象上。
function Point(x, y){
this.x = x;
this.y = y;
}
使用 apply 或 call 調(diào)用
讓我們?cè)僖淮沃厣?,?JavaScript 中函數(shù)也是對(duì)象,對(duì)象則有方法,apply 和 call 就是函數(shù)對(duì)象的方法。這兩個(gè)方法異常強(qiáng)大,他們?cè)试S切換函數(shù)執(zhí)行的上下文環(huán)境(context),即 this 綁定的對(duì)象。很多 JavaScript 中的技巧以及類庫(kù)都用到了該方法。讓我們看一個(gè)具體的例子:
function Point(x, y){
this.x = x;
this.y = y;
this.moveTo = function(x, y){
this.x = x;
this.y = y;
}
}
var p1 = new Point(0, 0);
var p2 = {x: 0, y: 0};
p1.moveTo(1, 1);
p1.moveTo.apply(p2, [10, 10]);
在上面的例子中,我們使用構(gòu)造函數(shù)生成了一個(gè)對(duì)象 p1,該對(duì)象同時(shí)具有 moveTo 方法;使用對(duì)象字面量創(chuàng)建了另一個(gè)對(duì)象 p2,我們看到使用 apply 可以將 p1 的方法應(yīng)用到 p2 上,這時(shí)候 this 也被綁定到對(duì)象 p2 上。另一個(gè)方法 call 也具備同樣功能,不同的是最后的參數(shù)不是作為一個(gè)數(shù)組統(tǒng)一傳入,而是分開傳入的。
function Foo(){
//1.this引用的構(gòu)造函數(shù)是argument.callee引用的對(duì)象
//說明是通過new操作符執(zhí)行的構(gòu)造函數(shù)
if(this.constructor==arguments.callee){
alert('Object Created');
}
//2.this是window, 那么是全局調(diào)用
if(this==window){
alert('normal call');
}
else{//3.否則是作為其他對(duì)象的方法來調(diào)用
alert('called by '+ this.constructor);
}
}
Foo();//全局函數(shù)調(diào)用
Foo.call(new Object());//作為一個(gè)object對(duì)象的成員方法來調(diào)用
new Foo();//被new操作符調(diào)用,執(zhí)行對(duì)象構(gòu)造
相關(guān)文章
js和jquery判斷數(shù)據(jù)類型的4種方法總結(jié)
這篇文章主要給大家介紹了關(guān)于js和jquery判斷數(shù)據(jù)類型的4種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08JS組件Form表單驗(yàn)證神器BootstrapValidator
做Web開發(fā)的我們,表單驗(yàn)證是再常見不過的需求了。友好的錯(cuò)誤提示能增加用戶體驗(yàn)。今天就來看看bootstrapvalidator如何使用,感興趣的小伙伴們可以參考一下2016-01-01JavaScript作用域、閉包、對(duì)象與原型鏈概念及用法實(shí)例總結(jié)
這篇文章主要介紹了JavaScript作用域、閉包、對(duì)象與原型鏈,結(jié)合實(shí)例形式總結(jié)分析了javascript中變量與函數(shù)的作用域、閉包、對(duì)象、原形鏈相關(guān)概念、用法及注意事項(xiàng),需要的朋友可以參考下2018-08-08D3.js實(shí)現(xiàn)簡(jiǎn)潔實(shí)用的動(dòng)態(tài)儀表盤的示例
本篇文章主要介紹了D3.js實(shí)現(xiàn)簡(jiǎn)潔實(shí)用的動(dòng)態(tài)儀表盤的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-04