奶头挺立呻吟高潮av全片,成人试看120秒体验区,性欧美极品v,A片高潮抽搐揉捏奶头视频

網頁設計

深入理解Javascript中的this關鍵字

時間:2024-10-04 14:52:05 網頁設計 我要投稿
  • 相關推薦

深入理解Javascript中的this關鍵字

  文章主要介紹了深入理解Javascript中的this關鍵字,本文講解了方法調用模式、函數調用模式、構造器調用模式、apply調用模式中this的不同之處,需要的朋友可以參考下,就跟隨百分網小編一起去了解下吧,想了解更多相關信息請持續關注我們應屆畢業生考試網!

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

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

  理解this

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

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

  this是執行上下文的一個屬性,而不是變量對象的一個屬性。 這個特性非常重要,因為與變量相反,this從不會參與到標識符解析過程。換句話說,在代碼中當訪問this的時候,它的值是直接從執行上下文中獲取的,并不需要任何作用域鏈查找。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.函數調用模式

  3.構造器調用模式

  4.apply調用模式

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

  方法調用模式

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

  代碼如下:

  // 創建myObject。它有一個value屬性和一個increment方法

  var myObject = {

  value: 0;

  increment: function(inc) {

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

  }

  };

  myObject.increment();

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

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

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

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

  函數調用模式

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

  代碼如下:

  // 給myObject增加一個double方法

  var myObject = {

  value: 0;

  increment: function(inc) {

  this.value += typeof inc ==='number'?inc:1; // 接受一個可選參數,如果不是數字,則默認為數字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,那么內部函數就可以通過那個變量訪問到this,按照約定,給那個變量命名為that。

  構造器調用模式

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

  復制代碼 代碼如下:

  //構造一個名為Quo的構造器函數,帶有一個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不是指的原型對象,而是調用對象。

  再回過頭看一開始的demo,就很好理解了,在執行myTest.fun()時,this指代了myTest對象,所以生成了一個foo屬性值為“banana”,所以myTest.hasOwnProperty("foo")返回值為true。

  Apply調用模式

  因為javascript是一門函數式面向對象編程語言,所以函數可以擁有方法。apply方法讓我們構建一個參數數組并用其去調用其他函數,apply方法接收兩個參數,第一個是將被綁定的this的值,第二個是參數數組。說簡單直接一點就是apply方法能劫持另外一個對象的方法,繼承另外一個對象的屬性. 推薦可以看js中apply方法的使用詳細解析 ,就不擺demo了。

  學識尚淺,若文中有不正確,請務必指出,誤人子弟實乃大過。

【深入理解Javascript中的this關鍵字】相關文章:

理解java中的關鍵字06-22

PHP中this關鍵字06-08

對Java中HashMap和TreeMap的區別的深入理解06-09

深入理解java的反射07-16

Java編程中this關鍵字與super關鍵字的使用方法08-23

解析Java中volatile關鍵字09-28

深入理解PHP的.htaccess文件08-11

如何深入理解photoshop通道09-14

最新的Java容器類的深入理解09-05

淺談Java線程中斷的本質深入理解08-23

主站蜘蛛池模板: 宁乡县| 收藏| 澎湖县| 措勤县| 乐都县| 汕尾市| 安庆市| 洮南市| 宿迁市| 西畴县| 浦东新区| 青铜峡市| 北碚区| 鸡西市| 十堰市| 合水县| 铁力市| 百色市| 玉门市| 瑞昌市| 永兴县| 南投县| 临安市| 怀柔区| 陕西省| 梁河县| 沁源县| 阿克苏市| 正镶白旗| 柳林县| 六盘水市| 灵寿县| 马鞍山市| 磐石市| 洪雅县| 乌兰县| 芮城县| 万载县| 长泰县| 兰考县| 尚义县|