深入淺出分析javaScript中this用法
本文實(shí)例講述了javaScript中this用法。分享給大家供大家參考。具體分析如下:
之前學(xué)javascript的時(shí)候總搞不清this,這個(gè)this不像java里的this那么好理解。我后來也是看了許多別人寫的文章,才理解過來的?,F(xiàn)在把別人寫的東西搬過來,怕以后忘記。
總得來說 this的指向分三種。指向全局window,該對(duì)象,構(gòu)造函數(shù)。
結(jié)論:在Javascript中,this指向函數(shù)執(zhí)行時(shí)的當(dāng)前對(duì)象。 簡單點(diǎn)說就是調(diào)用的方法屬于哪個(gè)對(duì)象,this就指向那個(gè)對(duì)象。
1. 全局window
簡單代碼
var message = "this in window"; var printMessage = function(){ console.info(this === window); console.info(this.message); }; printMessage();
因?yàn)檎{(diào)用方法printMessage是屬于window的,所以輸出結(jié)果為:
true this in window
現(xiàn)在如果將代碼改復(fù)雜點(diǎn)
var message = "this in window"; var printMessage = function(){ console.info(this === window); console.info(this.message); }; var obj = { message: 'this in obj', printMsg : function(){ printMessage(); } }; obj.printMessage();
此時(shí)printMessage方法是屬于window的,所以他的this還是指向window。obj.printMessage 方法是屬于obj對(duì)象的,看看下面的分析。
所以輸出結(jié)果還是為:true this in window
2. 該對(duì)象
現(xiàn)在看看該對(duì)象的,稍微改一下代碼
var message = "this in window"; var printMessage = function(){ console.info(this === window); console.info(this.message); }; var obj = { message: 'this in obj', printMessage : window.printMessage }; obj.printMessage();
結(jié)果:
false this in obj
對(duì)的,你想的沒錯(cuò) , 還是上一步的結(jié)論,obj.printMessage 方法是屬于obj對(duì)象的,所以this是指向obj的。
好的再嘔心點(diǎn),看代碼:
var message = "this in window"; var printMessage = function(){ console.info(this === window); console.info(this.message); }; var obj = { message: 'this in obj', printMessage : function(){ var obj2 = { message:'this in obj2', printMessage: window.printMessage }; obj2.printMessage(); } }; obj.printMessage();
最終調(diào)用的是 obj2.printMessage(),所以執(zhí)行到this的時(shí)候,那個(gè)this是obj2
結(jié)果:
false,this in obj2
哈哈,是不是和你想的一樣,誰調(diào)用的,就指向誰。
3. 構(gòu)造函數(shù)
var Person = function(){ this.age = 1; this.name = 'no name'; }; var p = new Person(); console.info('age = ' + p.age); console.info('name = ' + p.name);
結(jié)果:
age = 1 name = no name。
那么構(gòu)造函數(shù)對(duì)this作了什么呢? 前面講的《深入淺出理解javaScript原型鏈》 有對(duì)new做分析。
var Person = function(){}; var p = new Person();
new的過程拆分成以下三步:
(1) var p={}; 也就是說,初始化一個(gè)對(duì)象p
(2) p.__proto__ = Person.prototype;
(3) Person.call(p); 也就是說構(gòu)造p,也可以稱之為初始化p
那么就來說說call。
call 方法
應(yīng)用于:Function 對(duì)象
調(diào)用一個(gè)對(duì)象的一個(gè)方法,以另一個(gè)對(duì)象替換當(dāng)前對(duì)象。
call([thisObj[,arg1[, arg2[, [,.argN]]]]])
參數(shù):
thisObj
可選項(xiàng)。將被用作當(dāng)前對(duì)象的對(duì)象。
arg1, arg2, , argN
可選項(xiàng)。將被傳遞方法參數(shù)序列。
說明:
call 方法可以用來代替另一個(gè)對(duì)象調(diào)用一個(gè)方法。call 方法可將一個(gè)函數(shù)的對(duì)象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對(duì)象。如果沒有提供 thisObj 參數(shù),那么 Global 對(duì)象被用作 thisObj。
解釋一下,call方法的作用其實(shí)是更改默認(rèn)方法的this指向。調(diào)用call方法的肯定是一個(gè)方法對(duì)象,當(dāng)調(diào)用call,方法對(duì)象的this指向會(huì)變成call方法的第一個(gè)參數(shù),就這么簡單。
var p = new Person();
當(dāng)調(diào)用構(gòu)造函數(shù)Person時(shí),可能是通過call來處理,使Person內(nèi)的this指向了p,this.age = 1 就相當(dāng)于p.age = 1,這樣就張p添加了age這個(gè)屬性。
希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。
相關(guān)文章
微信小程序返回箭頭跳轉(zhuǎn)到指定頁面實(shí)例解析
這篇文章主要介紹了微信小程序返回箭頭跳轉(zhuǎn)到指定頁面實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10javascript判斷是手機(jī)還是電腦訪問網(wǎng)頁的簡單實(shí)例分享
在智能手機(jī)越來越普及甚至是泛濫的時(shí)候,確實(shí)給大家的生活帶來了很大的方便,但是對(duì)于web前端設(shè)計(jì)師來說,可就麻煩多了,現(xiàn)在很多的網(wǎng)站在制作過程中都要考慮到手機(jī)訪問的問題,那么我們?nèi)绾蝸砼袛嗫蛻舳耸遣皇鞘謾C(jī)呢,下面分享個(gè)例子吧2014-06-06JS自定義函數(shù)實(shí)現(xiàn)時(shí)間戳轉(zhuǎn)換成date的方法示例
這篇文章主要介紹了JS自定義函數(shù)實(shí)現(xiàn)時(shí)間戳轉(zhuǎn)換成date的方法,結(jié)合具體實(shí)例形式分析了javascript時(shí)間戳與日期格式的計(jì)算與轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2017-08-08js+canvas實(shí)現(xiàn)驗(yàn)證碼功能
這篇文章主要為大家詳細(xì)介紹了js+canvas實(shí)現(xiàn)驗(yàn)證碼功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07淺析JavaScript回調(diào)函數(shù)應(yīng)用
這篇文章主要為大家詳細(xì)介紹了JavaScript回調(diào)函數(shù)應(yīng)用,感興趣的朋友可以參考一下2016-05-05js彈出層永遠(yuǎn)居中實(shí)現(xiàn)思路及代碼
彈出層永遠(yuǎn)居中的方法有很多,在本文為大家詳細(xì)介紹下使用js是如何輕松實(shí)現(xiàn)的,喜歡的朋友可以參考下2013-11-11js中判斷一個(gè)數(shù)是不是素?cái)?shù)的三種方法例子
這篇文章主要給大家介紹了關(guān)于js中如何判斷一個(gè)數(shù)是不是素?cái)?shù)的三種方法,素?cái)?shù)(只能被1和本身整除的數(shù))規(guī)律:把這個(gè)數(shù)除以它之前的每一個(gè)數(shù)(從2開始)只要找到一個(gè)整除(余數(shù)為0)就是非素?cái)?shù),需要的朋友可以參考下2023-10-10JavaScript判斷用戶是否對(duì)表單進(jìn)行了修改的方法
這篇文章主要介紹了JavaScript判斷用戶是否對(duì)表單進(jìn)行了修改的方法,實(shí)例分析了javascript對(duì)表單操作與判定的技巧,需要的朋友可以參考下2015-03-03JS動(dòng)態(tài)調(diào)用方法名示例介紹
在JS中如何動(dòng)態(tài)調(diào)用方法名,想必很多的朋友們都不會(huì)吧,下面為大家舉例介紹下具體的調(diào)用方法2013-12-12