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

JavaScript函數(shù)中this指向問題詳解

 更新時間:2021年05月07日 09:59:24   作者:一顆不甘墜落的流星  
這篇文章主要給大家介紹了關(guān)于JavaScript函數(shù)中this指向問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

this關(guān)鍵字

哪個對象調(diào)用函數(shù),函數(shù)里面的this指向哪個對象。

**嚴格模式下:**在全局環(huán)境中,this指向的是undefined

**非嚴格模式下:**在全局環(huán)境中,this指向的是window

全局定義的函數(shù)直接調(diào)用,this => window

function fn(){
	console.log(this);
	// 此時 this 指向 window
}
fn();
// 相當于 window.fn()

對象內(nèi)部的函數(shù)調(diào)用,this => 調(diào)用者

var obj = {
	fn:function(){
		console.log(this);
	}
}
obj.fn();
// 此時 this 指向 obj

定時器的處理函數(shù),this => window

setTimeout(function(){
	console.log(this);	
},0)
// 此時定時器處理函數(shù)里面的this 指向 window

事件處理函數(shù),this => 事件源

div.onclick = function(){
	console.log(this);
}
//當你點擊 div 的時候,this指向 div

自調(diào)用函數(shù),this => window

(function () {
  console.log(this)
})()
// 此時 this 指向 window

改變 this 指向

剛才我們說過的都是函數(shù)的基本調(diào)用方式里面的 this 指向,我們還有三個方法可以忽略函數(shù)本身的 this 指向轉(zhuǎn)而指向別的地方。這三個方法就是 call / apply / bind,是強行改變 this 指向的方法。

  • call/apply/bind附加在函數(shù)調(diào)用后面使用,可以忽略函數(shù)本身的 this 指向
  • call和apply使用時會立即自動調(diào)用函數(shù),bind使用時會創(chuàng)建一個函數(shù),但是需要另外去手動調(diào)用

call

語法:fn.call(fn 函數(shù)體內(nèi) this 的指向哪里,arg1, arg2, ...);

作用:調(diào)用被綁定的函數(shù)fn,指定它的 this 指向并傳參

參數(shù):

  • 第一個參數(shù):是 this 指向
  • 其余的參數(shù):需要傳入的值,可以是多個,用逗號隔開

使用 call 方法不傳參

var num = 666;

function fn() {
  console.log('num = ', this.num);
}

fn.call();  // num = 666

使用 call 方法指定this

var name = 'Rose';
var obj = {name:'Jack'};
function fn(){
	console.log(this.name);
}
fn();	// Rose
fn.call();	// Rose
fn.call(obj);  // jack

使用 call 方法指定this并傳參

var name = 'Rack';
var obj = {name:'Jack'};
function fn(a,b){
	console.log(this,a,b);
}
fn(1,2);	// window 1 2
fn.call(obj,1,2);	// obj 1 2
fn(1,3);	// window 1 3

apply

apply方法接受的是一個包含多個參數(shù)的數(shù)組

語法:fn.apply(fn 函數(shù)體內(nèi) this 的指向哪里,[arg1, arg2, ...]);

作用:調(diào)用被綁定的函數(shù)fn,指定它的 this 指向并傳參

參數(shù):

  • 第一個參數(shù):this 指向的對象
  • 第二個參數(shù):一個包含多個參數(shù)的數(shù)組
var obj = {name:'jack'};
function fn(a,b){
	console.log(this,a,b);
}
fn(1,2);	// window 1 2
fn.apply(obj,[1,2]);	// obj 1 2

使用 apply 合并數(shù)組

使用push將元素追加到數(shù)組中,如果參數(shù)是數(shù)組,它會將該數(shù)組作為單個元素添加,而不是將這個數(shù)組內(nèi)的每個元素添加進去,因此我們最終會得到一個數(shù)組內(nèi)的數(shù)組

var arr1 = [1,2];
var arr2 = [3,4];
arr1.push(arr2);
console.log(arr1);	//	[1,2,[3,4]]	

concat雖然可以合并數(shù)組,但它并不是將元素添加到現(xiàn)有數(shù)組,而是創(chuàng)建并返回一個新數(shù)組。

var arr1 = [1,2];
var arr2 = [3,4];

var arr3 = arr1.concat(arr2);
console.log(arr1);	// [1,2]
console.log(arr3);	// [1,2,3,4]

如果我們要將元素追加到現(xiàn)有數(shù)組又該怎么做?循環(huán)?No!這是apply就派上用場了

var arr1 = [1,2];
var arr2 = [3,4];

arr1.push.apply(arr1,arr2);
console.log(arr1);	// [1,2,3,4]

使用 apply 與內(nèi)置函數(shù)連用

/* 找出數(shù)組中最大/小的數(shù)字 */
var numbers = [5, 6, 2, 3, 7];

var max = Math.max(numbers)
var min = Math.min(numbers)
console.log(min,max);	// NaN NaN

var max = Math.max.apply(null, numbers); 
/* 基本等同于 Math.max(numbers[0], ...) 或 Math.max(5, 6, ..) */
var min = Math.min.apply(null, numbers);
console.log(min,max);	// 2 7

bind

語法:fn.bind(fn 函數(shù)體內(nèi) this 的指向, arg1, arg2, ...);

作用:創(chuàng)建一個新的綁定函數(shù),指定它的 this 指向并傳參,必須調(diào)用它才會被執(zhí)行

參數(shù):

  • 第一個參數(shù):this 指向的對象
  • 其余的參數(shù):需要傳入的值,可以是多個,用逗號隔開
var obj = {name:'jack'};
function fn(a,b){
	console.log(this,a,b);
}
fn(1,2);	// window 1 2
fn.bind(obj,1,2);	// 未調(diào)用不執(zhí)行
fn.bind(obj,1,3)()	// obj 1 3
var newFn = fn.bind(obj,3,4);
newFn();	// obj 1 4
newFn(5,6);	// obj 3 4

總結(jié)

到此這篇關(guān)于JavaScript函數(shù)中this指向問題的文章就介紹到這了,更多相關(guān)JavaScript函數(shù)this指向內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Javascript實現(xiàn)base64的加密解密方法示例

    Javascript實現(xiàn)base64的加密解密方法示例

    下文是base64用javascript寫出來的函數(shù)和方法。非常不錯,具有參考借鑒價值,需要的的朋友參考下吧
    2017-06-06
  • 微信小程序?qū)崿F(xiàn)紅包功能(后端PHP實現(xiàn)邏輯)

    微信小程序?qū)崿F(xiàn)紅包功能(后端PHP實現(xiàn)邏輯)

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)紅包功能,以及后端PHP實現(xiàn)邏輯,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • javascript將中國數(shù)字格式轉(zhuǎn)換成歐式數(shù)字格式的簡單實例

    javascript將中國數(shù)字格式轉(zhuǎn)換成歐式數(shù)字格式的簡單實例

    下面小編就為大家?guī)硪黄猨avascript將中國數(shù)字格式轉(zhuǎn)換成歐式數(shù)字格式的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • JavaScript中的全局對象介紹

    JavaScript中的全局對象介紹

    這篇文章主要介紹了JavaScript中的全局對象介紹,對于任何JavaScript程序,當程序開始運行時,JavaScript解釋器都會初始化一個全局對象以供程序使用,需要的朋友可以參考下
    2015-01-01
  • 用函數(shù)式編程技術(shù)編寫優(yōu)美的 JavaScript_ibm

    用函數(shù)式編程技術(shù)編寫優(yōu)美的 JavaScript_ibm

    函數(shù)式編程語言在學術(shù)領(lǐng)域已經(jīng)存在相當長一段時間了,但是從歷史上看,它們沒有豐富的工具和庫可供使用。隨著 .NET 平臺上的 Haskell 的出現(xiàn),函數(shù)式編程變得更加流行。一些傳統(tǒng)的編程語言,例如 C++ 和 JavaScript,引入了由函數(shù)式編程提供的一些構(gòu)造和特性。在許多情況下,JavaScript 的重復代碼導致了一些拙劣的編碼。如果使用函數(shù)式編程,就可以避免這些問題。此外,可以利用函數(shù)式編程風格編寫更加優(yōu)美的回調(diào)。
    2008-05-05
  • JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果

    JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果

    這篇文章主要介紹了JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果,滾動有兩種方案,其一,利用路由中的meta,在離開頁面時緩存 top 信息,其二,利用keep-alive緩存整個頁面。但是僅限于沒有實時數(shù)據(jù)變動的頁面,需要的朋友可以參考下本文
    2022-06-06
  • IntersectionObserver API 詳解篇

    IntersectionObserver API 詳解篇

    這篇文章主要介紹了IntersectionObserver API 詳解篇,需要的朋友可以參考下
    2016-12-12
  • 新浪微博字數(shù)統(tǒng)計 textarea字數(shù)統(tǒng)計實現(xiàn)代碼

    新浪微博字數(shù)統(tǒng)計 textarea字數(shù)統(tǒng)計實現(xiàn)代碼

    從新浪微博代碼里抄的,非常不錯,需要的朋友可以參考下。
    2011-08-08
  • 使用js實現(xiàn)雪花飄落效果

    使用js實現(xiàn)雪花飄落效果

    以下是對使用js實現(xiàn)雪花飄落的效果進行了介紹。需要的朋友可以 過來參考下
    2013-08-08
  • 原生JS封裝vue Tab切換效果

    原生JS封裝vue Tab切換效果

    這篇文章主要為大家詳細介紹了原生JS封裝vue Tab切換效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04

最新評論