最大胆的大胆西西人艺人术_欧美在线看片a免费观看_欧美人与动人物a级_国产欧美日韩va另类在线播放

泰州上元教育

主營:泰州教育培訓,泰州資格證書考試培訓,泰州技能培訓

免費店鋪在線升級

聯(lián)系方式
  • 公司: 泰州上元教育
  • 地址: 泰州海陵區(qū)百腦匯寫字樓8樓830上元教育
  • 聯(lián)系: 沈老師
  • 手機: 18752624191
  • 一鍵開店
產品信息

泰州海陵區(qū)IT培訓,深入理解this關鍵字

2022-04-10 09:42:31  176次瀏覽 次瀏覽
價 格:面議

自從接觸javascript以來,對this參數(shù)的理解一直是模棱兩可。雖有過深入去理解,但卻也總感覺是那種浮于表面,沒有完全理清頭緒。

但對于this參數(shù),確實會讓人產生很多誤解。那么this參數(shù)到底是何方神圣?

理解this

this是一個與執(zhí)行上下文(execution context,也就是作用域)相關的特殊對象。因此,它可以叫作上下文對象(也就是用來指明執(zhí)行上下文是在哪個上下 文中被觸發(fā)的對象)。

任何對象都可以做為上下文中的this的值。在一些對ECMAScript執(zhí)行上下文和部分this的描述中的 所產生誤解。this經常被錯誤的描述成是變量對象的一個屬性。 再重復一次:

this是執(zhí)行上下文的一個屬性,而不是變量對象的一個屬性。 這個特性非常重要,因為與變量相反,this從不會參與到標識符解析過程。換句話說,在代碼中當訪問this的時候,它的值是直接從執(zhí)行上下文中獲取的,并不需要任何作用域鏈查找。this的值只在進入上下文的時候進行一次確定。

廢話不多,先看一個板栗:

代碼如下:

var test = function(){};

test.prototype = {

foo:"apple",

fun:function(){

this.foo="banana";

}

};

var myTest = new test();

myTest.fun();

console.log(myTest.hasOwnProperty("foo")); //輸出什么

console.log(myTest.hasOwnProperty("fun")); //輸出什么

hasOwnProperty:是用來判斷一個對象是否有你給出名稱的屬性或對象。不過需要注意的是,此方法無法檢查該對象的原型鏈中是否具有該屬性,該屬性必須是對象本身的一個成員。

不知道看官們心里的答案是什么,正確的答案是true,false。

代碼如下:

console.log(myTest.hasOwnProperty("foo"));

console.log(myTest.hasOwnProperty("fun"));

true

false

要弄明白為什么是這樣,就必須要理解上面this所扮演的角色,所指代的對象。在《javascript語言精粹》一書中,指出了在javascript中一共有四種調用模式:

1.方法調用模式

2.函數(shù)調用模式

3.構造器調用模式

4.apply調用模式

而在這些模式當中,對于如何初始化關鍵參數(shù)this上是存在不同差異的。

方法調用模式

當一個函數(shù)被保存為對象的一個屬性時,我們稱它為一個方法。當一個方法被調用時,this被綁定到該對象。注意加粗的這句是重點:

代碼如下:

// 創(chuàng)建myObject。它有一個value屬性和一個increment方法

var myObject = {

value: 0;

increment: function(inc) {

this.value += typeof inc ==='number'?inc:1; // 接受一個可選參數(shù),如果不是數(shù)字,則默認為數(shù)字1

}

};

myObject.increment();

console.log(myObject.value); // 1

myObject.increment(2); //傳入數(shù)字2

console.log(myObject.value); // 3

這里,方法increment可以使用this去訪問myObject對象,所以可以改變value的值。而且,this到對象的綁定發(fā)生在調用的時候。

函數(shù)調用模式

如果一個函數(shù)并非一個對象的屬性時,那么它被當作一個函數(shù)來調用,此時,this被綁定到全局對象,書上說這是js語言設計的一個缺陷。倘若設計正確,當內部函數(shù)被調用的時,this應該仍然綁定到外部函數(shù)的this變量。拋開對語言設計的正確與否討論,要當函數(shù)調用模式時this變量依舊綁定到該對象,有如下經典解決方案:

代碼如下:

// 給myObject增加一個double方法

var myObject = {

value: 0;

increment: function(inc) {

this.value += typeof inc ==='number'?inc:1; // 接受一個可選參數(shù),如果不是數(shù)字,則默認為數(shù)字1

}

};

myObject.increment(2);

myObject.double = function () {

var that=this; //解決方法

var helper= function () {

that.value=add(that.value,that.value);

};

helper();

};

myObject.double(); //以方法的形式調用double

console.log(myObject.getValue()); //6

即是給該方法定義一個變量并且把它賦值為this,那么內部函數(shù)就可以通過那個變量訪問到this,按照約定,給那個變量命名為that。

構造器調用模式

構造器調用模式即是我一開頭給出的例子所提到的。如果在一個函數(shù)前面帶上new來調用,那么將創(chuàng)建一個連接到該函數(shù)的prototype成員新對象,同時this將會被綁定到那個新對象上。聽上去十分拗口且難以理解,先再看個demo:

復制代碼 代碼如下:

//構造一個名為Quo的構造器函數(shù),帶有一個status屬性的對象

var Quo = function(string){

this.status =string;

};

Quo.prototype.get_status = function(){

return this.status;

}

var myQuo =new Quo("confuse"); //構造一個Quo實例

console.log(myQuo.get_status()); //confuse

簡單來說,Quo對象下的this在被用為構造一個新實例即new時,this指代的是新生成的myQuo對象而不是Quo對象本身。

一句話,重點就是:原型中的this不是指的原型對象,而是調用對象。

百業(yè)店鋪 更多 >

特別提醒:本頁面所展現(xiàn)的公司、產品及其它相關信息,均由用戶自行發(fā)布。
購買相關產品時務必先行確認商家資質、產品質量以及比較產品價格,慎重作出個人的獨立判斷,謹防欺詐行為。

回到頂部