亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

this,this,再次討論javascript中的this,超全面(經(jīng)典)

 更新時間:2016年01月05日 15:56:25   作者:八面碰壁居士  
在JavaScript中,this 的概念比較復(fù)雜。除了在面向?qū)ο缶幊讨?,this 還是隨處可用的。這篇文章介紹了javascript中的this相關(guān)知識,對javascript this相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧

JavaScript 是一種腳本語言,因此被很多人認為是簡單易學(xué)的。然而情況恰恰相反,JavaScript 支持函數(shù)式編程、閉包、基于原型的繼承等高級功能。本文僅采擷其中的一例:JavaScript 中的 this 關(guān)鍵字,深入淺出的分析其在不同情況下的含義,形成這種情況的原因以及 Dojo 等 JavaScript 工具中提供的綁定 this 的方法??梢赃@樣說,正確掌握了 JavaScript 中的 this 關(guān)鍵字,才算邁入了 JavaScript 這門語言的門檻。

 至于js中this這個東西,好多淫解釋過了,看起來好高端的樣子,不曉得你看懂了木有?

先引用比較高端的,腳本之家里 的, yes this 

好了,下面加上鄙人比較挫的解釋

論點: this 不是變量,不是屬性,不能為其賦值,它始終指向調(diào)用它的對象

感覺還TM太虛了,只要記住最重要的一條即可 ”它始終指向調(diào)用它的對象“ ,所以找到調(diào)用this的對象,就知道this到底指向誰了

1、

alert(this); 

瞅瞅,彈出來的是么子,要么是”object window“ ,要么 "object" 總之就對象了,是那個對象呢?

alert(this === window); 

結(jié)果為'true' 所以了,現(xiàn)在調(diào)用它的對象是window了

2、

var test = function(){
  alert(this);
}
test(); 

猜猜上面彈出什么,是不是和"alert(this)" 這句一樣的

var test = function(){
  alert(this === window);
 }
test(); 

運行上面的代碼,是不是彈出了'true' ?

事情就這樣完了?

要這么簡單的話,何必那么多人都去論述這個鳥了?

3、

再來

var test = function(){
  alert(this === window);
 }
new test(); 

哎哎,這次咋成'false'呢?

記住”this 始終指向調(diào)用它的對象“,第”1、“處調(diào)用該段代碼的直接對象是全局對象,即"window" ;第”2、“處雖然是函數(shù),但是調(diào)用其的仍然是”window“(不要弄混了,函數(shù)雖然是對象,但是調(diào)用它的是另一個對象);第”3、“處,使用了”new“ 這時其實已經(jīng)發(fā)生變化了,這是一個構(gòu)造函數(shù),構(gòu)造函數(shù)創(chuàng)建時創(chuàng)建了一個新的空的對象,即”new test()“創(chuàng)建了一個新的對象,然后再由這個對象指向函數(shù)"test"中的代碼,因此此時this不在是window對象,而是該構(gòu)造函數(shù)創(chuàng)建的新對象。

4、

var test ={
  'a':1,
  'b':function(){
   alert(this === test)
  }
 }
test.b(); 

有了上面的論點,這下一下子清楚了吧!

5、

var test ={
  'a':1,
  'b':function(){
   alert(this === test)
  }
 }
var test1 = test;
test1.b(); 

so, 你不會認為結(jié)果為"false"吧,錯了,雖然'test1'的值為'test'  但是'test1'不還是'test'對象么,它有新產(chǎn)生對象,你暫且理解為引用的了,兩個都指向一個對象,奉上下面一段代碼為證

var test ={
  'a':1,
  'b':function(){
   alert(this === test)
  }
 }
var test1 = test;
test.a = 2;
alert(test1.a); 

如果彈出了”1“,你來罵我

6、再整個復(fù)雜的

var test ={
  'a':1,
  'b':{
   'b1':function(){
    alert(this === test);
   }
  }
 }
test.b.b1(); 

這是"true"還是"false"呢?

按照上面的理論,這時"this"不再直接被'test'調(diào)用了,而是被'test.b' 調(diào)用, 奉上下面一段代碼為證

var test ={
  'a':1,
  'b':{
   'b1':function(){
    alert(this === test.b);
   }
  }
 }
test.b.b1(); 

 7、好再整個復(fù)雜點的

var test = function(){
  var innerTest = function(){
   alert(this === test);
  }
  innerTest();
 }
test(); 

你不會認為彈出"true"吧,不是按照上面的理論'innerTest'是被'test'調(diào)用的,然后'this'就指向'test'嗎?
額,錯就錯在是誰調(diào)用的'innerTest', 其實這種函數(shù)都是'window'對象調(diào)用的,及時你嵌套一千層,調(diào)用各個函數(shù)的都是'window'對象,奉上下面這段代碼為證

var test = function(){
  var innerTest = function(){
   alert(this === window);
   var innerTest1 = function(){
    alert(this === window);
   }
   innerTest1();
  }
  innerTest();
 }
test(); 

8、再來一段特殊的

var test = function(){
  alert(this === window);
 }
var test1 = {
}
test.apply(test1); 

這個我覺得大家都不會猜錯,該函數(shù)的作用就是”調(diào)用一個對象的一個方法,以另一個對象替換當(dāng)前對象“ 所以了'window' 對象已經(jīng)被替代為'test1',自然為'false'了,奉上如下代碼以為證明

var test = function(){
  alert(this === test1);
 }
 var test1 = {
  }
test.apply(test1); 

 那么諸如'call'之類的也就相似了

9、再來一個原型的繼承,區(qū)別于字面量的繼承

var test = function(){
 }
 var my = function(){
  this.a = function(){
   alert(this === mytest2);
  }
 }
 var mytest = new my();
 test.prototype = mytest;
 var mytest2 = new test();
 mytest2.a(); 

10、還剩下些什么了,可能就是'dom'對象了

<script>
  var mytest = function(context){
   alert(context.getAttribute('id'));
   alert(this === window);
  }
 </script>
 <div id="test" onclick="mytest(this)">aaaa</div> 

看了上面的應(yīng)該了解了吧,里面的'this'分別代表神馬

相關(guān)文章

  • 詳解webpack2異步加載套路

    詳解webpack2異步加載套路

    這篇文章主要介紹了詳解webpack2異步加載套路,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • 枚舉JavaScript對象的函數(shù)

    枚舉JavaScript對象的函數(shù)

    枚舉JavaScript對象的函數(shù)...
    2006-12-12
  • 網(wǎng)上應(yīng)用的一個不錯common.js腳本

    網(wǎng)上應(yīng)用的一個不錯common.js腳本

    網(wǎng)上應(yīng)用的一個不錯common.js腳本...
    2007-08-08
  • JavaScript對象解構(gòu)的用法實例解析

    JavaScript對象解構(gòu)的用法實例解析

    解構(gòu)賦值允許你使用類似數(shù)組或?qū)ο笞置媪康恼Z法將數(shù)組和對象的屬性賦給各種變量,下面這篇文章主要給大家介紹了關(guān)于JavaScript對象解構(gòu)用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-01-01
  • Javascript設(shè)置對象的ReadOnly屬性(示例代碼)

    Javascript設(shè)置對象的ReadOnly屬性(示例代碼)

    本篇文章主要介紹了Javascript設(shè)置對象的ReadOnly屬性(示例代碼) 需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • javascript實現(xiàn)簡單小鋼琴有聲彈奏效果

    javascript實現(xiàn)簡單小鋼琴有聲彈奏效果

    用HTML5+javascript實現(xiàn)的小鋼琴,按下鋼琴鍵上的相應(yīng)字母用或用鼠標(biāo)點擊鋼琴鍵發(fā)聲,javascript代碼包含了對鼠標(biāo)按下、移動和松開,以及鍵盤按下的事件監(jiān)聽
    2024-02-02
  • 如何屏蔽防止別的網(wǎng)站嵌入框架代碼

    如何屏蔽防止別的網(wǎng)站嵌入框架代碼

    目前,國內(nèi)很流行一種流氓行為:使用框架(Frame),將你的網(wǎng)頁嵌入它的網(wǎng)頁中,如何防止嵌入框架代碼呢,下面小編給大家整理了相關(guān)資料,如何屏蔽防止別的網(wǎng)站嵌入框架代碼,需要的朋友一起來學(xué)習(xí)下
    2015-08-08
  • JavaScript及jquey實現(xiàn)多個數(shù)組的合并操作

    JavaScript及jquey實現(xiàn)多個數(shù)組的合并操作

    這篇文章主要介紹了JavaScript及jquey實現(xiàn)多個數(shù)組的合并操作,在某些情況下還是比較實用的,需要的朋友可以參考下
    2014-09-09
  • 利用原生JavaScript實現(xiàn)造日歷輪子實例代碼

    利用原生JavaScript實現(xiàn)造日歷輪子實例代碼

    這篇文章主要給大家介紹了關(guān)于如何利用原生JavaScript實現(xiàn)造日歷輪子的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • javascript淘寶主圖放大鏡功能

    javascript淘寶主圖放大鏡功能

    這篇文章主要為大家詳細介紹了javascript淘寶主圖放大鏡功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10

最新評論