欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入淺出分析javaScript中this用法

 更新時間:2015年05月09日 10:41:41   作者:nicholaszjb  
這篇文章主要介紹了javaScript中this用法,實例分析了javascript中this的用途與相關的使用技巧,需要的朋友可以參考下

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

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

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

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

1. 全局window

簡單代碼

var message = "this in window";
var printMessage = function(){
  console.info(this === window);
  console.info(this.message);
};
printMessage();

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

true   this in window

現(xià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();

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

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

2. 該對象

現(xiàn)在看看該對象的,稍微改一下代碼

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();

結果:

false        this in obj

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

好的再嘔心點,看代碼:

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();

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

結果:

false,this in obj2

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

3. 構造函數(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);

結果:

age = 1 name = no name。

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

var Person = function(){};
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]]]]])

參數(shù):
thisObj
可選項。將被用作當前對象的對象。
arg1, arg2, , argN
可選項。將被傳遞方法參數(shù)序列。

說明:
call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象。如果沒有提供 thisObj 參數(shù),那么 Global 對象被用作 thisObj。

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

var p = new Person(); 

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

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

相關文章

  • 微信小程序返回箭頭跳轉到指定頁面實例解析

    微信小程序返回箭頭跳轉到指定頁面實例解析

    這篇文章主要介紹了微信小程序返回箭頭跳轉到指定頁面實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-10-10
  • javascript判斷是手機還是電腦訪問網頁的簡單實例分享

    javascript判斷是手機還是電腦訪問網頁的簡單實例分享

    在智能手機越來越普及甚至是泛濫的時候,確實給大家的生活帶來了很大的方便,但是對于web前端設計師來說,可就麻煩多了,現(xiàn)在很多的網站在制作過程中都要考慮到手機訪問的問題,那么我們如何來判斷客戶端是不是手機呢,下面分享個例子吧
    2014-06-06
  • JS自定義函數(shù)實現(xiàn)時間戳轉換成date的方法示例

    JS自定義函數(shù)實現(xiàn)時間戳轉換成date的方法示例

    這篇文章主要介紹了JS自定義函數(shù)實現(xiàn)時間戳轉換成date的方法,結合具體實例形式分析了javascript時間戳與日期格式的計算與轉換相關操作技巧,需要的朋友可以參考下
    2017-08-08
  • js+canvas實現(xiàn)驗證碼功能

    js+canvas實現(xiàn)驗證碼功能

    這篇文章主要為大家詳細介紹了js+canvas實現(xiàn)驗證碼功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • 淺析JavaScript回調函數(shù)應用

    淺析JavaScript回調函數(shù)應用

    這篇文章主要為大家詳細介紹了JavaScript回調函數(shù)應用,感興趣的朋友可以參考一下
    2016-05-05
  • js彈出層永遠居中實現(xiàn)思路及代碼

    js彈出層永遠居中實現(xiàn)思路及代碼

    彈出層永遠居中的方法有很多,在本文為大家詳細介紹下使用js是如何輕松實現(xiàn)的,喜歡的朋友可以參考下
    2013-11-11
  • js中判斷一個數(shù)是不是素數(shù)的三種方法例子

    js中判斷一個數(shù)是不是素數(shù)的三種方法例子

    這篇文章主要給大家介紹了關于js中如何判斷一個數(shù)是不是素數(shù)的三種方法,素數(shù)(只能被1和本身整除的數(shù))規(guī)律:把這個數(shù)除以它之前的每一個數(shù)(從2開始)只要找到一個整除(余數(shù)為0)就是非素數(shù),需要的朋友可以參考下
    2023-10-10
  • JavaScript?WebGL?圖片透明處理的方式

    JavaScript?WebGL?圖片透明處理的方式

    WebGL 透明處理方式之一是使用 α 混合,這篇文章主要介紹了JavaScript?WebGL?圖片透明處理方式,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • JavaScript判斷用戶是否對表單進行了修改的方法

    JavaScript判斷用戶是否對表單進行了修改的方法

    這篇文章主要介紹了JavaScript判斷用戶是否對表單進行了修改的方法,實例分析了javascript對表單操作與判定的技巧,需要的朋友可以參考下
    2015-03-03
  • JS動態(tài)調用方法名示例介紹

    JS動態(tài)調用方法名示例介紹

    在JS中如何動態(tài)調用方法名,想必很多的朋友們都不會吧,下面為大家舉例介紹下具體的調用方法
    2013-12-12

最新評論