下面小編就為大家帶來一篇深入理解js函數的作用域與this指向。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟著小編過來看看吧
函數的作用域與this指向是js中很重要的一部分,理清這點東西需要個邏輯,看看我的邏輯怎麼樣...
以下是個提綱,可以直接挑你有興趣的條目來閱讀。
• 函數的定義方式:直接定義(window下,內部定義),物件的方法,物件原型的方法;
• 函數的呼叫方式:直接調用,call/apply,with
• 對於直接定義的函數和物件的方法,作用域預設狀態下是它的定義處的作用域鏈。
• 對於直接定義的函數,this指向window。
• 對於物件的方法,this指向實例化物件(對應於實例化物件預設回傳this的情況)。
• 用call/apply改變方法的this指向
• 在函數或方法的定義時可以透過with改變其作用域鏈。
下面分開來具體說:
函數的定義,如提綱中提到的可以分為兩種:直接定義( window下,內部定義),物件的方法(或物件原型的方法)。從下面的範例程式碼中可以看到函數fn1與fn2以及物件的方法doFunction在函數使用name時name的值來自對應的域。
var name = 'window下的name<br/>'; var resultCon; function fn1() { resultCon.innerHTML += name; } function MyObj() { var name = 'MyObj下的name<br/>'; this.doFunction = function() { resultCon.innerHTML += name;
在使用name的值時將「name」用「this.name」來取代會出現什麼情況呢,看下例:
var name = 'window下的name<br/>'; var resultCon; function fn1() { resultCon.innerHTML += this.name; } function MyObj() { var name = 'MyObj下的name<br/>'; this.doFunction = function() { resultCon.innerHTML += this.name;
從結果來看可以驗證提綱中的第4和5條,也可以看到this和作用域是兩套分離的鏈,遵循個自的變數查詢邏輯,具體的查詢邏輯在下面的效能分析會提到,如果是新手建議先看一下「js的作用域鏈」方面的基礎知識。
關於函數的呼叫方法,我用下面的方範例說明提綱中的第2、6條:
var name = 'window下的name<br/>'; var resultCon; function fn1() { resultCon.innerHTML += this.name; } function MyObj() { var name = 'MyObj下的name<br/>'; this.doFunction = function() { resultCon.innerHTML += this.name;
呼叫時call和apply的使用是為了改變被呼叫函數的this指向。 with的使用是為了改變被呼叫函數中變數的查詢域。我們把上例中的call和name前的this去掉再加上with來示範with的作用。
var name = 'window下的name<br/>'; var resultCon; function fn1(myScope) { with (myScope) { resultCon.innerHTML += name; } } function MyObj(myScope) { var name = 'MyObj下的name<br/>';
看到with的使用並不方便,需要在被呼叫函數中加入with,有人可能想能不能向下面那樣呼叫來整體改變變數作用域而不去改變被呼叫函數呢?
with (myScope) { fn1(); fn2(); var obj = new MyObj(); obj.doFunction(); }
很遺憾,不行!所以在一些成熟的框架中隨處可見call和apply的使用,卻很少用到with,在用JSHint檢測js語法的時候with處都標了小紅點,在一些js編碼指導中也建議盡量少用with,因為with改變了變數的預設查詢鏈,所以會給後期的維修人員一些困惑,還有效能方面的一些考慮,請慎用with。
以上是詳細介紹JavaScript函數的作用域與this指向的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

禪工作室 13.0.1
強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器