精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

別再為了this發愁了:JS中的this機制

開發 前端
JavaScript中有很多令人困惑的地方,或者叫做機制。但是,就是這些東西讓JavaScript顯得那么美好而與眾不同。比方說函數也是對象、閉包、原型鏈繼承等等,而這其中就包括頗讓人費解的this機制。不管是新手還是老手,不仔細深摳一下還真鬧不明白this倒地咋回事捏。今天,我們就一起看一下this倒地咋回事,別再為了this發愁了。

[[187723]]

題記:JavaScript中有很多令人困惑的地方,或者叫做機制。但是,就是這些東西讓JavaScript顯得那么美好而與眾不同。比方說函數也是對象、閉包、原型鏈繼承等等,而這其中就包括頗讓人費解的this機制。不管是新手還是老手,不仔細深摳一下還真鬧不明白this倒地咋回事捏。今天,我們就一起看一下this倒地咋回事,別再為了this發愁了。

1、this是啥?

簡言之,this是JavaScript語言中定義的眾多關鍵字之一,它的特殊在于它自動定義于每一個函數域內,但是this倒地指引啥東西卻讓很多人張二摸不著頭腦。這里我們留個小懸念,希望看完這篇文章了你能回答出來this到底指引個甚。

2、this有啥用?

那邊觀眾又該問了,既然this這么難以理解,那么為個甚還要用它呢?我們來看個例子:

  1. function identify() { 
  2.  
  3.     return this.name.toUpperCase(); 
  4.  
  5.  
  6. function sayHello() { 
  7.  
  8.     var greeting = "Hello, I'm " + identify.call( this ); 
  9.  
  10.     console.log( greeting ); 
  11.  
  12.  
  13. var person1= { 
  14.  
  15.     name"Kyle" 
  16.  
  17. }; 
  18.  
  19. var person2= { 
  20.  
  21.     name"Reader" 
  22.  
  23. }; 
  24.  
  25. identify.call( person1); // KYLE 
  26.  
  27. identify.call( person2); // READER 
  28.  
  29. sayHello.call( person1); // Hello, I'm KYLE 
  30.  
  31. sayHello.call( person2); // Hello, I'm READER  

這段代碼很簡單,我們定義了兩個函數,分別為identify和sayHello。并且在不同的對象環境下執行了它們,達到了復用的效果,而不用為了在不同的對象環境下執行而必須針對不同的對象環境寫對應的函數了。簡言之,this給函數帶來了復用。那邊客官又問了,我不用this一樣可以實現,如:

  1. function identify(context) { 
  2.  
  3.     return context.name.toUpperCase(); 
  4.  
  5.  
  6. function sayHello(context) { 
  7.  
  8.     var greeting = "Hello, I'm " + identify( context); 
  9.  
  10.     console.log( greeting ); 
  11.  
  12.  
  13. var person1= { 
  14.  
  15.     name"Kyle" 
  16.  
  17. }; 
  18.  
  19. var person2= { 
  20.  
  21.     name"Reader" 
  22.  
  23. }; 
  24.  
  25. identify( person1); // KYLE 
  26.  
  27. identify( person2); // READER 
  28.  
  29. sayHello( person1); // Hello, I'm KYLE 
  30.  
  31. sayHello( person2); // Hello, I'm READER  

仔細一看,這位客官給出的解決方法的確也達到了類似的效果。贊一個!我想說的是,隨著代碼的增加,函數嵌套、各級調用等變得越來越復雜,那么傳遞一個對象的引用將變得越來越不明智,它會把你的代碼弄得非常亂,甚至你自己都無法理解清楚。而this機制提供了一個更加優雅而靈便的方案,傳遞一個隱式的對象引用讓代碼變得更加簡潔和復用。好了,知道了this的用處,那么再看看我們對它的誤解。

3、關于this的誤解

相信很多童鞋是學過其它語言的,在很多編程語言中都有this的機制,慣性思維把其它語言里對它的理解帶到了JavaScript中。同時,由于this這個單詞的理解導致了我們產生了對它各種各樣的誤解。所以,開始前,我們先澄清下對它的誤解。

3.1 誤解一:this引用function本身

我們都知道,在函數里引用函數可以達到遞歸和給函數屬性賦值的效果。而這在很多應用場景下顯得非常有用。所以,很多人都誤以為this就是指引function本身。例如:

  1. function fn(num) { 
  2.  
  3.     console.log( "fn: " + num ); 
  4.  
  5.     // count用于記錄fn的被調用次數 
  6.  
  7.     this.count++; 
  8.  
  9.  
  10. fn.count = 0; 
  11.  
  12. var i; 
  13.  
  14. for (i=0; i<10; i++) { 
  15.  
  16.     if (i > 5) { 
  17.  
  18.         fn( i ); 
  19.  
  20.     } 
  21.  
  22.  
  23. // fn: 6 
  24.  
  25. // fn: 7 
  26.  
  27. // fn: 8 
  28.  
  29. // fn: 9 
  30.  
  31.   
  32.  
  33. console.log( fn.count ); // 0 -- 耶?咋不是4捏?  

上面我們想要記錄fn被調用的次數,可是明顯fn被調用了四次但count仍然為0。咋回事捏?這里簡單解釋下,fn里第4行的自增隱式的創建了一個全局變量count,由于初始值為undefined,所以每一次自增其實依然不是一個數字,你在全局環境下打印count(window.count)輸出的應該是NaN。而第6行定義的函數熟悉變量count依然沒變,還是0。如果對這個執行結果不清楚的,歡迎去看我前些天的那篇博文(聊一下JS中的作用域scope和閉包closure scope和closure),在這里你只需要知道,this引用的是function這種理解是錯誤的就行。

這邊就會又有人問了,既然this不是引用function,那么我要實現遞歸函數,該咋引用呢?這里簡單回答下介個問題,兩種方法:①函數體內用函數名來引用函數本身②函數體內使用arguments.callee來引用函數(不推薦)。那么既然第二種方法不推薦,匿名函數咋引用呢?用***種,并且給匿名函數一個函數名即可(推薦)。

3.2 誤解二:this引用的是function的詞法作用域

這種誤解欺騙的人可能更多一些。首先,澄清一下,this并沒有引用function的詞法作用域。的確JS的引擎內對詞法作用域的實現的確像是一個對象,擁有屬性和函數,但是這僅僅是JS引擎的一種實現,對代碼來說是不可見的,也就是說詞法作用域“對象”在JS代碼中取不到。(關于詞法作用域,如果不理解,可以參考之前的一篇博文《聊一下JS中的作用域scope和閉包closure scope和closure》)??磦€錯誤的例子:

  1. function fn1() { 
  2.  
  3.     var a = 2; 
  4.  
  5.     this.fn2();//以為this引用的是fn1的詞法作用域 
  6.  
  7.  
  8. function fn2() { 
  9.  
  10.     console.log( this.a ); 
  11.  
  12.  
  13. fn1(); //ReferenceError  

上面的代碼明顯沒有執行出想要的結果,從而可以看到this并沒有引用函數的詞法作用域。甚至,可以肯定的說,這個例子里fn2可以在fn1里正確執行都是偶然的(理解了詞法作用域你就知道為什么這里執行不報錯了)。

4、this到底跟啥有關?

好了,扯了那么多都沒上干貨,有的觀眾都開始關閉當前頁開始離席了。這里,我們鄭重聲明:this跟函數在哪里定義沒有半毛錢關系,函數在哪里調用才決定了this到底引用的是啥。也就是說this跟函數的定義沒關系,跟函數的執行有大大的關系。所以,記住,“函數在哪里調用才決定了this到底引用的是啥”。

5、this機制的四種規則

this到底綁定或者引用的是哪個對象環境決定于函數被調用的地方。而函數的調用有不同的方式,在不同的方式中調用決定this引用的是哪個對象是由四種規則確定的。我們一個個來看。

5.1 默認綁定全局變量

這條規則是最常見的,也是默認的。當函數被單獨定義和調用的時候,應用的規則就是綁定全局變量。如下:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var a = 2; 
  7.  
  8. fn(); // 2 -- fn單獨調用,this引用window  

5.2 隱式綁定

隱式調用的意思是,函數調用時擁有一個上下文對象,就好像這個函數是屬于該對象的一樣。例如:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.     a: 2, 
  9.  
  10.     fn: fn 
  11.  
  12. }; 
  13.  
  14. obj.fn(); // 2 -- this引用obj。  

需要說明的一點是,***一個調用該函數的對象是傳到函數的上下文對象(繞懵了)。如:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj2 = { 
  7.  
  8.     a: 42, 
  9.  
  10.     fn: fn 
  11.  
  12. }; 
  13.  
  14. var obj1 = { 
  15.  
  16.     a: 2, 
  17.  
  18.     obj2: obj2 
  19.  
  20. }; 
  21.  
  22. obj1.obj2.fn(); // 42 -- this引用的是obj2.  

還有一點要說明的是,失去隱式綁定的情況,如下:

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.     a: 2, 
  9.  
  10.     fn: fn 
  11.  
  12. }; 
  13.  
  14. var bar = obj.fn; // 函數引用傳遞 
  15.  
  16. var a = "全局"; // 定義全局變量 
  17.  
  18. bar(); // "全局"  

如上,第8行雖然有隱式綁定,但是它執行的效果明顯是把fn賦給bar。這樣bar執行的時候,依然是默認綁定全局變量,所以輸出結果如上。

5.3 顯示綁定

學過bind()\apply()\call()函數的都應該知道,它接收的***個參數即是上下文對象并將其賦給this??聪旅娴睦樱?/p>

  1. function fn() { 
  2.  
  3.     console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.     a: 2 
  9.  
  10. }; 
  11.  
  12. fn.call( obj ); // 2  

如果我們傳遞***個值為簡單值,那么后臺會自動轉換為對應的封裝對象。如果傳遞為null,那么結果就是在綁定默認全局變量,如:

  1. function fn() { 
  2.  
  3.      console.log( this.a ); 
  4.  
  5.  
  6. var obj = { 
  7.  
  8.      a: 2 
  9.  
  10. }; 
  11.  
  12. var a = 10; 
  13.  
  14. fn.call( null); // 10  

5.4 new新對象綁定

如果是一個構造函數,那么用new來調用,那么綁定的將是新創建的對象。如:

  1. function fn(a) { 
  2.  
  3.     this.a = a; 
  4.  
  5.  
  6. var bar = new fn( 2 ); 
  7.  
  8. console.log( bar.a );// 2  

注意,一般構造函數名首字母大寫,這里沒有大寫的原因是想提醒讀者,構造函數也是一般的函數而已。

6、結束語

讀到現在,1中問的問題你該自己能回答上來了。上面介紹的四種關于this綁定的4中情況和規則,現實寫代碼的過程中肯定比這要多和復雜,但是無論多復雜多亂,它們都是混合應用上面的幾個規則和情況而已。只要你的思路和理解是清晰的,那肯定沒問題的。 

責任編輯:龐桂玉 來源: 前端大全
相關推薦

2025-06-09 01:20:00

2021-06-16 00:57:16

JVM加載機制

2022-05-27 21:56:55

索引存儲MySQL 存儲引擎

2024-01-10 17:13:42

模型數據

2020-12-04 10:05:00

Pythonprint代碼

2020-12-02 11:18:50

print調試代碼Python

2020-06-15 08:12:51

try catch代碼處理器

2025-08-13 03:00:00

2025-05-19 04:00:00

2025-06-27 02:33:00

ServiceSpring事件

2017-08-16 09:55:36

2025-06-10 02:22:00

2025-11-03 04:00:00

2011-03-15 10:20:44

VMware環境虛擬化平臺選型

2013-12-24 13:40:13

程序員代碼

2021-06-09 06:41:11

OFFSETLIMIT分頁

2018-09-28 05:25:53

TopK算法代碼

2020-07-17 07:15:38

數據庫ID代碼

2023-10-26 07:40:15

2020-11-02 11:40:24

Node.jsRequire前端
點贊
收藏

51CTO技術棧公眾號

国产伦精品免费视频| 欧美精品乱码久久久久久按摩| 国产综合动作在线观看| 无码人妻久久一区二区三区 | 男人的天堂亚洲| 中日韩午夜理伦电影免费 | 秋霞无码一区二区| 国产高清av在线| 国产经典欧美精品| 日韩美女中文字幕| 久久精品视频6| 日韩欧美一区二区三区免费看| 精品国一区二区三区| 青青在线视频免费| 久久不射影院| 亚洲欧洲成人av每日更新| 国产呦系列欧美呦日韩呦| 这里只有精品9| 国产手机视频一区二区| 不卡伊人av在线播放| 妺妺窝人体色WWW精品| 99re91这里只有精品| 在线观看av黄网站永久| 在线播放亚洲一区| 国产精品 日韩| 久久久久久无码精品大片| 国产精品分类| 久久久精品电影| 蜜臀久久99精品久久久久久| 第一区第二区在线| 日韩一级片网址| 我要看一级黄色大片| 成人美女大片| 午夜久久电影网| 日本道在线视频| 在线免费黄色| 国产精品视频线看| 欧美日韩在线一二三| 婷婷久久久久久| 成熟亚洲日本毛茸茸凸凹| 成人在线免费观看视视频| 国产精品无码一区| 日本伊人精品一区二区三区观看方式 | 欧美一级淫片播放口| 久久久全国免费视频| 亚洲综合小说| 久久在线免费视频| caoporn91| 三区四区不卡| 久久激情视频免费观看| 开心激情五月网| 99久久婷婷| www.久久久久| 搜索黄色一级片| 一区二区三区中文| 欧美区在线播放| 精品在线视频免费| 尤物在线精品| 97视频免费看| 国产专区第一页| 玖玖玖国产精品| 国产精品女人久久久久久| 中文字幕1区2区3区| 美腿丝袜一区二区三区| 国产精品一区电影| 国产欧美综合视频| 成人免费毛片app| 麻豆91蜜桃| 在线观看免费高清完整| 亚洲欧洲制服丝袜| 国产va亚洲va在线va| 中文字幕成在线观看| 色88888久久久久久影院野外| 亚洲国产精品三区| 精品亚洲a∨一区二区三区18| 日韩免费性生活视频播放| 色悠悠在线视频| 亚洲妇女av| 精品国产一区二区在线| 免费一级片在线观看| 国产精品亚洲综合色区韩国| 国产精品爱久久久久久久| 国产免费黄色大片| proumb性欧美在线观看| 日韩一区不卡| 尤物yw193can在线观看| 欧美日韩激情美女| 9l视频白拍9色9l视频| 亚洲91网站| 亚洲一级一级97网| 久久99久久久| 日韩av一区二区三区| 91精品国产自产在线老师啪| 空姐吹箫视频大全| 欧美激情中文不卡| 欧美日韩午夜爽爽| 午夜无码国产理论在线| 欧美成人精品3d动漫h| av电影网站在线观看| 欧美色123| 国产精品久久久久久久久男| 亚洲免费国产视频| 国产精品无人区| 真人抽搐一进一出视频| 免费视频成人| 国产午夜精品理论片a级探花| 日本一级特级毛片视频| 老色鬼久久亚洲一区二区| 产国精品偷在线| 生活片a∨在线观看| 欧美日韩国产一区二区三区| 极品粉嫩美女露脸啪啪| 免费成人av| 欧美黄色小视频| 一本色道久久综合精品婷婷| 97国产精品videossex| 亚洲欧美日韩不卡| 巨胸喷奶水www久久久| 亚洲成av人影院在线观看| 99成人在线观看| 玖玖在线精品| 蜜桃视频成人| 日韩电影毛片| 亚洲大胆人体在线| 欧美特级一级片| 麻豆中文一区二区| 欧美日韩喷水| 综合日韩av| 亚洲精品久久久久中文字幕欢迎你 | 黄色一级片播放| 欧美久久一区二区三区| 色综合亚洲精品激情狠狠| 国产黄网在线观看| 2023国产精品| 国产成人亚洲精品无码h在线| 国产精品毛片视频| 久久久爽爽爽美女图片| 精品人妻一区二区三区蜜桃| 亚洲视频免费在线观看| 天天影视色综合| 国产亚洲精品美女久久久m| 亚洲制服国产| 欧美不卡一区二区三区四区| 国产十六处破外女视频| 国产老女人精品毛片久久| 最新中文字幕久久| 国产日本亚洲| 欧美激情免费看| 手机看片福利在线| 五月婷婷综合在线| 国产精品第七页| 亚洲在线免费| 日韩欧美精品一区二区三区经典 | 亚洲韩日在线| 精品久久sese| 欧美日韩成人影院| 中文字幕亚洲无线码在线一区| 在线视频免费观看一区| 亚洲视频你懂的| 在线观看一区二区三区四区| 日韩一级大片| 日本在线成人一区二区| 久久免费影院| 色综合久久中文字幕综合网小说| 99精品在线看| 精品国产91久久久| 日本污视频网站| 国产一区二区在线影院| 人人妻人人澡人人爽欧美一区| 加勒比久久高清| 国产成人av网址| 亚洲xxxxxx| 欧美成人精品福利| 亚洲黄网在线观看| 中文字幕一区二区在线播放| 一二三区视频在线观看| 亚洲三级观看| 亚洲v国产v在线观看| 国产一区 二区| 18性欧美xxxⅹ性满足| 川上优的av在线一区二区| 制服丝袜在线91| 久久久久久久极品| 国产精品成人免费| 日本一卡二卡在线| 毛片av中文字幕一区二区| youjizz.com在线观看| 精品日本12videosex| 91文字幕巨乱亚洲香蕉| 深夜成人福利| 欧美日产国产成人免费图片| 国产在线视频福利| 日韩精品一区二| 国产成人a v| 亚洲成人av电影在线| 久久久国产一级片| 93久久精品日日躁夜夜躁欧美| 中日韩av在线播放| 一本久久综合| 日韩视频一二三| 精品一区二区三区在线| 国产麻豆乱码精品一区二区三区 | 久久久久资源| 欧美二区观看| 国产精品美女主播| 欧美aa免费在线| 欧美国产日本在线| 免费av网站在线观看| 亚洲精品有码在线| 成人av免费播放| 在线成人午夜影院| 69视频免费看| 欧美午夜视频在线观看| 妺妺窝人体色www婷婷| 中文字幕五月欧美| av电影在线不卡| 99精品欧美一区二区蜜桃免费| 天天爽夜夜爽视频| 毛片不卡一区二区| 日韩av片网站| 老牛影视一区二区三区| 草草久久久无码国产专区| 中文在线播放一区二区| 天堂社区 天堂综合网 天堂资源最新版| 成午夜精品一区二区三区软件| 国产日韩中文在线| 2019年精品视频自拍| 青青草国产精品一区二区| а√在线天堂官网| 久久久久久久97| 超碰在线网站| 久久免费少妇高潮久久精品99| 调教一区二区| 伦伦影院午夜日韩欧美限制| 黄色免费在线网站| 久久精品国产欧美亚洲人人爽| 最新电影电视剧在线观看免费观看| 亚洲欧美在线第一页| 日本天堂影院在线视频| 国产丝袜视频一区| 免费一级毛片在线观看| 亚洲欧美国产一区二区三区| 日韩av资源| 亚洲欧美在线第一页| 国产日产精品久久久久久婷婷| 亚洲精品自在久久| 精品久久av| 色偷偷91综合久久噜噜| 国内外激情在线| 久久成人在线视频| 欧美韩日亚洲| 97视频免费在线观看| 中文字幕影音在线| 国产999在线观看| 国产成人免费精品| 成人免费自拍视频| 日韩欧美另类中文字幕| 国产精品综合久久久久久| 日日狠狠久久偷偷综合色| 欧美日韩亚洲在线| 久久麻豆精品| www.欧美黄色| 久久久久久久欧美精品| 亚洲国产高清av| 国产二区国产一区在线观看| 精品1卡二卡三卡四卡老狼| 2023国产精品| 黄色精品视频在线观看| 亚洲午夜免费电影| 无码aⅴ精品一区二区三区| 欧美天天综合网| www.色婷婷.com| 日韩精品视频在线| 尤物网在线观看| 久久久久久久国产| 日本精品裸体写真集在线观看| 91网站在线免费观看| 久久悠悠精品综合网| 午夜精品一区二区在线观看| 欧美黄免费看| 波多野结衣家庭教师视频| 九色porny丨国产精品| 最新日本中文字幕| 中文av一区二区| 久热精品在线观看| 欧美色男人天堂| 男人天堂一区二区| 自拍偷拍亚洲在线| av中文资源在线资源免费观看| 国产精品久久久久秋霞鲁丝| 51精品国产| 亚洲精品国产一区| 亚洲高清免费| 欧美大片久久久| www.亚洲免费av| 熟女av一区二区| 无吗不卡中文字幕| 国产精品女同一区二区| 亚洲欧美日韩国产中文专区| а√天堂8资源在线官网| 欧美专区中文字幕| 亚洲2区在线| 在线免费一区| 日韩中文字幕一区二区三区| 中文字幕永久免费| 国产精品伦一区| 波多野结衣视频网站| 日韩一区二区免费在线电影| www.视频在线.com| 日本sm极度另类视频| 中文字幕区一区二区三| 正在播放精油久久| 日韩精品电影一区亚洲| 91丝袜在线观看| 一区二区三区在线观看视频 | 精品日韩成人av| 久cao在线| 国产精品一区二区久久久| 国产精品自在| 日韩精品在线中文字幕| 韩国av一区二区| 一级黄色片日本| 欧美色涩在线第一页| 免费在线一级视频| 欧美亚洲国产视频小说| 欧美大奶一区二区| 欧美高清中文字幕| 国产91丝袜在线观看| 亚洲二区在线播放| 欧美日本一区二区三区四区| 18视频免费网址在线观看| 国产精品电影网站| 不卡在线一区二区| 免费看黄色一级大片| 91老司机福利 在线| 国产高潮久久久| 亚洲欧美成人一区二区在线电影| 国产福利片在线观看| 久久精品五月婷婷| 亚洲欧美日韩精品一区二区| 欧美大片免费播放器| 午夜亚洲福利老司机| 亚洲精品免费在线观看视频| 欧美高清视频免费观看| 都市激情久久| 中国丰满人妻videoshd| 91丨porny丨中文| 成人免费视频国产免费| 国产一区二区动漫| 国产精品99久久久久久董美香| 亚洲欧美日韩精品在线| 捆绑紧缚一区二区三区视频| 中日韩一级黄色片| 91麻豆精品国产91久久久久久久久| 国产乱色在线观看| 超碰97在线资源| 国产精品美女久久久| 成人片黄网站色大片免费毛片| 欧美性生活影院| 蜜芽在线免费观看| 国产精品日韩欧美一区二区三区 | 国产一区二区三区站长工具| 999在线免费视频| 亚洲人亚洲人成电影网站色| 亚洲成熟女性毛茸茸| 97人人模人人爽人人喊中文字| 欧美三级午夜理伦三级小说| 黄色一级二级三级| 亚洲女同女同女同女同女同69| 午夜精品久久久久久久99| 91极品视频在线| 欧美日韩在线二区| 视频区 图片区 小说区| 午夜国产精品一区| 国产youjizz在线| 亚洲专区国产精品| 久久精品在线| 在线看的片片片免费| 亚洲国产日韩欧美在线99| 草民电影神马电影一区二区| 欧洲精品视频在线| 久久美女艺术照精彩视频福利播放 | 国产高潮在线| 一本一道久久a久久综合精品 | 狂野欧美性猛交xxxx巴西| 久久福利免费视频| 亚洲国产精品一区二区久| av成人免费看| 亚洲一区二区三区av无码| 国产日韩欧美高清| 日本加勒比一区| 国产日本欧美在线观看| 国产精品日韩精品欧美精品| 日韩高清dvd碟片| 亚洲欧美日韩国产成人| 97视频一区| 一二三av在线| 在线观看日韩电影| 国产盗摄在线视频网站| 一区二区三区四区欧美|