本篇內(nèi)容介紹了“js中的有哪些“this”指向值得了解”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
在東城等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需設(shè)計網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),營銷型網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站制作,東城網(wǎng)站建設(shè)費(fèi)用合理。
this是javascript中的一個關(guān)鍵字,其使用方法類似于一個變量,是執(zhí)行上下文中一個重要組成部分。其作用是可以在函數(shù)體內(nèi)部獲取當(dāng)前的運(yùn)行環(huán)境。
每個函數(shù)的this是在調(diào)用的時候基于函數(shù)的執(zhí)行環(huán)境綁定的,this的指向完全取決于函數(shù)的調(diào)用位置。(下面均是在瀏覽器環(huán)境下進(jìn)行測試的結(jié)果)
在全局環(huán)境下,this 始終指向全局對象(window), 無論是否嚴(yán)格模式;
console.log(this); // window
普通函數(shù)內(nèi)部的this分兩種情況,嚴(yán)格模式和非嚴(yán)格模式。
(1)非嚴(yán)格模式下,this 默認(rèn)指向全局對象window
(2)嚴(yán)格模式下, this為undefined
function fun() { console.log(this); // window }
對象內(nèi)部方法的this指向調(diào)用這些方法的對象
(1)函數(shù)的定義位置不影響其this指向,this指向只和調(diào)用函數(shù)的對象有關(guān);
(2)多層嵌套的對象,內(nèi)部方法的this指向離被調(diào)用函數(shù)最近的對象(window也是對象,其內(nèi)部對象調(diào)用方法的this指向內(nèi)部對象, 而非window)。
const obj = { a: 10, b: 20, add: function () { return this.a + this.b; } }; console.log(obj.add()); // 30 const add = obj.add; console.log(add()); // NaN
原型鏈中的方法的this仍然指向調(diào)用它的對象
const obj = { a: 10, b: 20 }; const prototypeObj = { add: function () { return this.a + this.b; } }; Object.setPrototypeOf(obj, prototypeObj); console.log(obj.add()); // 30
當(dāng)函數(shù)通過Function對象的原型中繼承的方法 call() 和 apply() 方法調(diào)用時, 其函數(shù)內(nèi)部的this值可綁定到 call() & apply() 方法指定的第一個對象上, 如果第一個參數(shù)不是對象,JavaScript內(nèi)部會嘗試將其轉(zhuǎn)換成對象然后指向它。(見后續(xù)代碼)
通過bind方法綁定后, 函數(shù)將被永遠(yuǎn)綁定在其第一個參數(shù)對象上, 而無論其在什么情況下被調(diào)用。(見后續(xù)代碼)
當(dāng)函數(shù)被當(dāng)做監(jiān)聽事件處理函數(shù)時, 其 this 指向觸發(fā)該事件的元素(針對于addEventListener事件)
<button id="testId">按鈕</button> const btn = document.getElementById('testId'); btn.addEventListener('click', function() { console.log(this); // <button id="testId">按鈕</button> });
內(nèi)聯(lián)事件中的this指向分兩種情況:
(1)當(dāng)代碼被內(nèi)聯(lián)處理函數(shù)調(diào)用時,它的this指向監(jiān)聽器所在的DOM元素
<button onclick="console.log(this)">按鈕</button> // 輸出該DOM節(jié)點(diǎn)
(2)當(dāng)代碼被包括在函數(shù)內(nèi)部執(zhí)行時,其this指向等同于 函數(shù)直接調(diào)用的情況,即在非嚴(yán)格模式指向全局對象window, 在嚴(yán)格模式指向undefined
<button onclick="clickFun()">按鈕</button> function clickFun() { console.log(this); // window }
對于延時函數(shù)內(nèi)部的回調(diào)函數(shù)的this指向全局對象window(當(dāng)然可以通過bind方法改變其內(nèi)部函數(shù)的this指向)
function Fun() { this.a = 10; this.method = function() { setTimeout(function() { console.log(this); // window }, 1000); } } const fun = new Fun(); fun.method();
由于箭頭函數(shù)不綁定this, 它會捕獲其所在(即定義的位置)上下文的this值, 作為自己的this值,所以 call() / apply() / bind() 方法對于箭頭函數(shù)來說只是傳入?yún)?shù),對它的 this 毫無影響。
function Fun() { this.a = 10; this.method = function() { setTimeout(() => { console.log(this); // Fun {a: 10, method: ƒ} }, 1000); } } const fun = new Fun(); fun.method();
除了隱式綁定this的方式,還能夠通過顯示綁定的方式,通過call、apply、bind方式改變this指向,對于這三者的區(qū)別后續(xù)將有專門的百題斬去闡述,本節(jié)主要進(jìn)行一波簡單使用。
call()
call() 方法使用一個指定的 this 值和單獨(dú)給出的一個或多個參數(shù)來調(diào)用一個函數(shù)。
function method(val1, val2) { return this.a + this.b + val1 + val2; } const obj = { a: 1, b: 2 }; console.log(method.call(obj, 3, 4)); // 10
apply()
apply() 方法調(diào)用一個具有給定this值的函數(shù),以及以一個數(shù)組(或類數(shù)組對象)的形式提供的參數(shù)。
function method(val1, val2) { return this.a + this.b + val1 + val2; } const obj = { a: 1, b: 2 }; console.log(method.apply(obj, [3, 4])); // 10
bind()
bind() 方法創(chuàng)建一個新的函數(shù),在 bind() 被調(diào)用時,這個新函數(shù)的 this 被指定為 bind() 的第一個參數(shù),而其余參數(shù)將作為新函數(shù)的參數(shù),供調(diào)用時使用。
function method(val1, val2) { return this.a + this.b + val1 + val2; } const obj = { a: 1, b: 2 }; const bindMethod = method.bind(obj, 3, 4); console.log(bindMethod); // [Function: bound method] console.log(bindMethod()); // 10
擴(kuò)展
call() 和 apply()的區(qū)別是call()方法接受的是參數(shù)列表,而apply()方法接受的是一個參數(shù)數(shù)組;
bind返回的是一個綁定函數(shù),而call和apply返回的是運(yùn)行結(jié)果;
多次 bind() 是無效的,只會綁定到第一次調(diào)用的對象上;
call() / apply() / bind() 方法對于箭頭函數(shù)來說只是傳入?yún)?shù),對它的 this 毫無影響。
“js中的有哪些“this”指向值得了解”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
網(wǎng)頁題目:js中的有哪些“this”指向值得了解
轉(zhuǎn)載來于:http://www.chinadenli.net/article36/jogcpg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、軟件開發(fā)、網(wǎng)站排名、定制網(wǎng)站、自適應(yīng)網(wǎng)站、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)