亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

深入淺出分析javaScript中this用法

2024-05-06 16:19:45
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了javaScript中this用法,實例分析了javascript中this的用途與相關的使用技巧,需要的朋友可以參考下

本文實例講述了javaScript中this用法。分享給大家供大家參考。具體分析如下:

之前學javascript的時候總搞不清this,這個this不像java里的this那么好理解。我后來也是看了許多別人寫的文章,才理解過來的?,F在把別人寫的東西搬過來,怕以后忘記。

總得來說 this的指向分三種。指向全局window,該對象,構造函數。

結論:在Javascript中,this指向函數執行時的當前對象。 簡單點說就是調用的方法屬于哪個對象,this就指向那個對象。

1. 全局window

簡單代碼

 

 
  1. var message = "this in window"
  2. var printMessage = function(){ 
  3. console.info(this === window); 
  4. console.info(this.message); 
  5. }; 
  6. printMessage(); 

因為調用方法printMessage是屬于window的,所以輸出結果為:

true this in window

現在如果將代碼改復雜點

 

 
  1. var message = "this in window"
  2. var printMessage = function(){ 
  3. console.info(this === window); 
  4. console.info(this.message); 
  5. }; 
  6. var obj = { 
  7. message: 'this in obj'
  8. printMsg : function(){ 
  9. printMessage(); 
  10. }; 
  11. obj.printMessage(); 

此時printMessage方法是屬于window的,所以他的this還是指向window。obj.printMessage 方法是屬于obj對象的,看看下面的分析。

所以輸出結果還是為:true this in window

2. 該對象

現在看看該對象的,稍微改一下代碼

 

 
  1. var message = "this in window"
  2. var printMessage = function(){ 
  3. console.info(this === window); 
  4. console.info(this.message); 
  5. }; 
  6. var obj = { 
  7. message: 'this in obj'
  8. printMessage : window.printMessage 
  9. }; 
  10. obj.printMessage(); 

結果:

false this in obj

對的,你想的沒錯 , 還是上一步的結論,obj.printMessage 方法是屬于obj對象的,所以this是指向obj的。

好的再嘔心點,看代碼:

 

 
  1. var message = "this in window"
  2. var printMessage = function(){ 
  3. console.info(this === window); 
  4. console.info(this.message); 
  5. }; 
  6. var obj = { 
  7. message: 'this in obj'
  8. printMessage : function(){ 
  9. var obj2 = { 
  10. message:'this in obj2'
  11. printMessage: window.printMessage 
  12. }; 
  13. obj2.printMessage(); 
  14. }; 
  15. obj.printMessage(); 

最終調用的是 obj2.printMessage(),所以執行到this的時候,那個this是obj2

結果:

false,this in obj2

哈哈,是不是和你想的一樣,誰調用的,就指向誰。

3. 構造函數

 

 
  1. var Person = function(){ 
  2. this.age = 1; 
  3. this.name = 'no name'
  4. }; 
  5. var p = new Person(); 
  6. console.info('age = ' + p.age); 
  7. console.info('name = ' + p.name); 

結果:

age = 1 name = no name。

那么構造函數對this作了什么呢? 前面講的《深入淺出理解javaScript原型鏈》 有對new做分析。

 

 
  1. var Person = function(){}; 
  2. var p = new Person(); 

new的過程拆分成以下三步:

(1) var p={}; 也就是說,初始化一個對象p

(2) p.__proto__ = Person.prototype;

(3) Person.call(p); 也就是說構造p,也可以稱之為初始化p

那么就來說說call。

call 方法

應用于:Function 對象

調用一個對象的一個方法,以另一個對象替換當前對象。

call([thisObj[,arg1[, arg2[, [,.argN]]]]])

參數:

thisObj

可選項。將被用作當前對象的對象。

arg1, arg2, , argN

可選項。將被傳遞方法參數序列。

說明:

call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數的對象上下文從初始的上下文改變為由 thisObj 指定的新對象。如果沒有提供 thisObj 參數,那么 Global 對象被用作 thisObj。

解釋一下,call方法的作用其實是更改默認方法的this指向。調用call方法的肯定是一個方法對象,當調用call,方法對象的this指向會變成call方法的第一個參數,就這么簡單。

var p = new Person();

當調用構造函數Person時,可能是通過call來處理,使Person內的this指向了p,this.age = 1 就相當于p.age = 1,這樣就張p添加了age這個屬性。

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合男人天堂| 欧美中文在线观看| 中日韩美女免费视频网站在线观看| 欧美日韩xxxxx| 国产黑人绿帽在线第一区| 欧美高清性猛交| 久久91超碰青草是什么| 亚洲国产成人久久综合一区| 久久男人的天堂| 久久精品国产清自在天天线| 国产精品成av人在线视午夜片| 中文字幕精品久久| 国产自摸综合网| 最近2019中文字幕大全第二页| 日韩av电影手机在线| 久久精品一区中文字幕| 国产精欧美一区二区三区| 欧美午夜视频一区二区| 亚洲成人精品视频| 美女久久久久久久久久久| 国产精品亚洲片夜色在线| 92看片淫黄大片看国产片| 日韩欧美高清在线视频| 日韩av123| 欧美日韩午夜剧场| 日韩一级黄色av| 中文字幕精品在线视频| 亚洲黄色片网站| 成人在线国产精品| 亚洲欧美中文日韩在线| 国产精品v片在线观看不卡| 国产免费一区二区三区在线能观看| 69av视频在线播放| 日韩高清中文字幕| 久久不射热爱视频精品| 欧美成人午夜视频| 国产精品久久久久久久电影| 亚洲跨种族黑人xxx| 久久久精品一区| 亚洲sss综合天堂久久| 亚洲精品久久久久中文字幕欢迎你| 欧美一级免费看| 日本国产欧美一区二区三区| 欧美日韩激情视频8区| 国产91在线高潮白浆在线观看| 国产精品一区二区久久国产| 国产精品久久久久久久久粉嫩av| 国产精彩精品视频| 亚洲成人动漫在线播放| 在线视频精品一| 国产香蕉97碰碰久久人人| 亚洲国产精品va在线观看黑人| 国语自产精品视频在线看抢先版图片| 欧美性xxxxx极品娇小| 欧美极品少妇xxxxⅹ免费视频| 日韩精品免费电影| 日韩精品在线影院| 亚洲无av在线中文字幕| 亚洲成人在线网| 亚洲大胆美女视频| 欧美中文在线视频| 91系列在线播放| 日韩欧美有码在线| 亚洲欧美综合精品久久成人| 国产精品日韩在线一区| 亚洲精品一区二区三区不| 久久久精品久久久| 欧美日韩亚洲精品一区二区三区| 91国产美女视频| 亚洲第一色中文字幕| 亚洲风情亚aⅴ在线发布| 亚洲乱码国产乱码精品精天堂| 色777狠狠综合秋免鲁丝| 日本中文字幕久久看| 日韩在线观看免费网站| 精品久久久久久久久国产字幕| 亚洲黄色www网站| 成人美女免费网站视频| 亚洲成色777777女色窝| 欧美日韩成人黄色| 热99精品只有里视频精品| 亚洲午夜精品视频| 欧美精品久久久久久久久久| 久久久亚洲影院| 久久国产色av| 欧美另类在线观看| 亚洲欧美成人一区二区在线电影| 欧美国产精品日韩| 欧美精品18videos性欧| 色偷偷亚洲男人天堂| 91在线中文字幕| 欧美成人免费在线视频| 欧美一区二三区| 日韩一二三在线视频播| 久久国产精品99国产精| 国产精品6699| 91系列在线播放| 欧美日韩成人精品| 日韩精品在线视频美女| 亚洲欧美日韩中文视频| 欧美日韩激情视频| 久热在线中文字幕色999舞| 日韩最新中文字幕电影免费看| 国产精品一区二区久久国产| 亚洲国产成人精品久久久国产成人一区| 亚洲欧美国产高清va在线播| 久久亚洲国产精品| 成人黄色短视频在线观看| 欧美日韩精品在线视频| 上原亚衣av一区二区三区| 日本久久中文字幕| 国产视频丨精品|在线观看| 亚洲美女av在线播放| 国产视频精品va久久久久久| 日韩中文在线中文网在线观看| 久久国产精品久久国产精品| 亚洲人成网在线播放| 国产一区二区视频在线观看| 日韩福利在线播放| 波霸ol色综合久久| 中日韩午夜理伦电影免费| 色综合久久悠悠| 亚洲国产日韩欧美在线动漫| 欧美日韩国产中文精品字幕自在自线| 亚洲国产欧美一区| 精品久久国产精品| 日韩精品视频免费| 8x海外华人永久免费日韩内陆视频| www.国产精品一二区| 国产成人精品一区| 国产成人一区二区| 成人av电影天堂| 国产日本欧美一区二区三区在线| 欧美日韩成人网| 91精品国产自产在线观看永久| 97视频色精品| 伦伦影院午夜日韩欧美限制| 97超级碰碰人国产在线观看| 欧美日韩国产va另类| 欧美日韩免费一区| 久久视频中文字幕| 26uuu国产精品视频| 伊人亚洲福利一区二区三区| 欧美精品在线第一页| 欧美精品午夜视频| 国产区亚洲区欧美区| 国产精品高清在线| 日韩视频免费在线观看| 日韩中文字幕亚洲| 2019中文字幕在线免费观看| 欧美巨乳在线观看| 亚洲激情在线视频| 亚洲国模精品一区| 欧美裸体男粗大视频在线观看| 国产精品久久久久久久久免费看| 播播国产欧美激情| 日韩专区在线播放| 青青草国产精品一区二区| 亚洲国产天堂网精品网站| 亚洲性日韩精品一区二区| 精品视频偷偷看在线观看| 9.1国产丝袜在线观看| 亚洲另类欧美自拍| 国产91成人video|