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

JavaScript中的this引用(推薦)

 更新時間:2016年08月05日 10:35:20   作者:libaoqing  
this是javascript的一個關(guān)鍵字,隨著函數(shù)使用場合不同,this的值會發(fā)生變化。這篇文章主要介紹了JavaScript中的this引用的相關(guān)資料,非常不錯,需要的朋友可以參考下

this

this是javascript的一個關(guān)鍵字,隨著函數(shù)使用場合不同,this的值會發(fā)生變化。但是總有一個原則,那就是this指的是調(diào)用函數(shù)的那個對象。

一、定義

1、this是函數(shù)內(nèi)部的一個特殊對象(或this引用)--它引用的是函數(shù)據(jù)以執(zhí)行的環(huán)境對象。

2、this引用是一種在JavaScript的代碼中隨時都可以使用的只讀變量。 this引用 引用(指向)的是一個對象,它有著會根據(jù)代碼上下文語境自動改變其引用對象的特性。它的引用規(guī)則如下:

• 在最外層代碼中,this引用 引用的是全局對象。

• 在函數(shù)內(nèi),this引用根據(jù)函數(shù)調(diào)用的方式的不同而有所不同。如下

1)構(gòu)造函數(shù)的調(diào)用--this引用 引用的是所生成的對象

2)方法調(diào)用--this引用 引用的是接收方對象

3)apply或call調(diào)用--this引用 引用的是有apply或call的參數(shù)指定的對象

4)其他方式的調(diào)用--this引用 引用的是全局對象

二、根據(jù)以上所述及網(wǎng)上的相關(guān)資料,this對象(引用)的使用情況總結(jié)如下:

JavaScript是動態(tài)語言,this關(guān)鍵字在執(zhí)行的時候才能確定是誰。所以this永遠指向調(diào)用者,即對“調(diào)用對象”的引用。簡單點說就是調(diào)用的方法屬于哪個對象,this就指向那個對象。根據(jù)函數(shù)調(diào)用方式的不同,this可以 指向全局對象,當前對象,或其他任意對象。

1、全局函數(shù)調(diào)用,全局函數(shù)中的this會指向全局對象window。(函數(shù)調(diào)用模式)

//代碼清單1
<script type="text/javascript">
var message = "this in window"; //這一句寫在函數(shù)外面和里面是一樣效果
function func() {
if(this == window){
alert("this == window"); 
alert(message);
this.methodA = function() {
alert("I'm a function");
}
}
}
func(); //如果不調(diào)用func方法,則里面定義的屬性或方法會取不到 
methodA();
</script>

func()的調(diào)用結(jié)果為this == window, this in window

methodA()的調(diào)用結(jié)果為I'm a function

2、構(gòu)造函數(shù)調(diào)用,即使用new的方式實例化一個對象,this會指向通過構(gòu)造函數(shù)生成的對象。(構(gòu)造器調(diào)用模式)

代碼清單2

<script type="text/javascript">
function Func() {
if (this == window) {
alert("this == window");
}
else {
alert("this != window");
}
this.fieldA = "I'm a field";
alert(this);
}
var obj = new Func();
alert(obj.fieldA); //this指向的是對象obj
</script>

3、對象方法的調(diào)用,this指向當前對象。任何函數(shù),只要該函數(shù)被當做一個對象的方法使用或賦值時,該函數(shù)內(nèi)部的this都是對該對象本身的引用。也可理解為this寫在一個普通對象中,this指向的就是對象本身。(方法調(diào)用模式)

(方法的定義: 作為對象屬性的函數(shù)稱為方法)

//代碼清單3
<script type="text/javascript">
var obj = {
x: 3,
doit: function(){
if(this == window){
alert("this == window");
}else{
alert("method is called: " + this.x);
}
}
};
obj.doit(); //this指向的是對象obj
</script>

4、通過apply或call方法調(diào)用,this指向傳入的對象。

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

//代碼清單4
<script type="text/javascript">
var obj = {
x: 3,
doit: function(){
alert("method is called: " + this.x);
}
};
var obj2 = {x: 4};
obj.doit(); //3,this指向obj
obj.doit.apply(obj2); //4,this指向obj2
obj.doit.call(obj2); //4,this指向obj2
</script>

5、原型鏈中的this --原型對象及構(gòu)造函數(shù)中的this指向新創(chuàng)建的實例對象。使用prototype擴展方法可以使用this獲取到源對象的實例,私有字段無法通過原型鏈獲取。

//代碼清單5
<script type="text/javascript">
function Func() {
this.fieldA = "I'm a field";
var privateFieldA = "I'm a var";
}
Func.prototype = {
ExtendMethod: function(str) {
alert(str + " :" + this.fieldA);
alert(privateFieldA); //出錯,私有字段無法通過原型鏈獲取。
}
};
var obj = new Func();
obj.ExtendMethod("From prototype"); //此時構(gòu)造函數(shù)及原型鏈中的this指向?qū)ο髈bj
</script>

6、閉包中的this --閉包:寫在function中的function,this指向全局對象window。

6.1 對象中的閉包

//代碼清單6
<script type="text/javascript">
var name = "The window";
var obj = {
name: "My Object",
getNameFunc: function(){
return function(){
return this.name;
}
}
};
alert(obj.getNameFunc()()); //The window
</script>

此時,閉包中的this指向全局對象window,只能取到全局對象的屬性。那么對象內(nèi)部的屬性(外部函數(shù)的變量)要想訪問又怎么辦呢? 把外部函數(shù)的this對象保存在一個閉包能訪問的變量就可以了??慈缦麓a:

//代碼清單7
<script type="text/javascript">
var name = "The window";
var obj = {
name: "My Object",
getNameFunc: function(){
var that = this;
return function(){
return that.name;
}
}
};
alert(obj.getNameFunc()()); //My object
</script>

將外部函數(shù)的this賦值給that變量,就能讀取到外部函數(shù)的變量。

6.2 不管是直接引用function,還是實例化一個function,其返回的閉包函數(shù)里的this都是指向window。

//代碼清單8
<script type="text/javascript">
function a() {
alert(this == window);
var that = this;
var func = function() {
alert(this == window);
alert(that);
};
return func;
}
var b = a();
b(); //true, true, [object Window]
var c = new a();
c(); //false, true, [object object]
</script>

7、函數(shù)使用bind()方法綁定一個對象,this會指向傳給bind()函數(shù)的值。

//代碼清單9
<script type="text/javascript">
window.color = "red";
var obj = {color: "blue"};
function sayColor(){
alert(this.color);
}
var objSayColor = sayColor.bind(obj);
objSayColor(); //blue
</script>

8、內(nèi)嵌在HTML元素中的腳本段,this指向元素本身

//代碼清單10
<div onclick="test(this)" id="div">Click Me</div>
<script type="text/javascript">
function test(obj) {
alert(obj); //[object HTMLDivElement]
}
</script>

9、寫在script標簽中:this就是指全局對象window。這個跟第一點的全局函數(shù)調(diào)用的全局變量一樣。

以上所述是小編給大家介紹的JavaScript中的this引用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 深入了解JavaScript 的 WebAssembly

    深入了解JavaScript 的 WebAssembly

    這篇文章主要介紹了深入了解JavaScript 的 WebAssembly,它是由 Google , Microsoft , Mozilla , Apple 等幾家大公司合作發(fā)起的一個關(guān)于 面向Web的通用二進制和文本格式 的項目。 ,需要的朋友可以參考下
    2019-06-06
  • 理解javascript中的with關(guān)鍵字

    理解javascript中的with關(guān)鍵字

    這篇文章主要幫助大家理解javascript中的with關(guān)鍵字,學(xué)習(xí)with關(guān)鍵字的作用,感興趣的小伙伴們可以參考一下
    2016-02-02
  • Javascript無阻塞加載具體方式

    Javascript無阻塞加載具體方式

    這篇文章介紹了JS無阻塞加載,有需要的朋友可以參考一下
    2013-06-06
  • js從外部獲取圖片的實現(xiàn)方法

    js從外部獲取圖片的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猨s從外部獲取圖片的實現(xiàn)方法。小編覺得挺不錯的, 現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • ajax java 實現(xiàn)自動完成功能

    ajax java 實現(xiàn)自動完成功能

    都知道百度建議是用ajax做的,想要做的快速穩(wěn)定,可復(fù)制可移植就不容易了,花時間研究還不如自己來寫。根據(jù)一個pdf文檔提供的資料,用了小半天時間,終于實現(xiàn)了。在此與大家分享
    2012-12-12
  • 詳解微信小程序網(wǎng)絡(luò)請求接口封裝實例

    詳解微信小程序網(wǎng)絡(luò)請求接口封裝實例

    這篇文章主要介紹了微信小程序網(wǎng)絡(luò)請求接口封裝,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • DataGear開發(fā)基于three.js的3D數(shù)據(jù)可視化看板的詳細代碼

    DataGear開發(fā)基于three.js的3D數(shù)據(jù)可視化看板的詳細代碼

    DataGear?支持采用原生的HTML、JavaScript、CSS制作數(shù)據(jù)可視化看板,也支持導(dǎo)入由npm、vite等前端工具構(gòu)建的前端程序包,這篇文章主要介紹了DataGear制作基于three.js的3D數(shù)據(jù)可視化看板,需要的朋友可以參考下
    2024-02-02
  • 詳解基于webpack&gettext的前端多語言方案

    詳解基于webpack&gettext的前端多語言方案

    這篇文章主要介紹了詳解基于webpack&gettext的前端多語言方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • JavaScript中使用replace結(jié)合正則實現(xiàn)replaceAll的效果

    JavaScript中使用replace結(jié)合正則實現(xiàn)replaceAll的效果

    JavaScript?中使用?replace?達到?replaceAll的效果,其實就用利用的正則的全局替換。
    2010-06-06
  • 分享兩段簡單的JS代碼防止SQL注入

    分享兩段簡單的JS代碼防止SQL注入

    下面小編就為大家分享兩段簡單的JS代碼防止SQL注入。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-04-04

最新評論