您好,登錄后才能下訂單哦!
這篇文章主要講解了“javascript中的函數知識點有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“javascript中的函數知識點有哪些”吧!
JavaScript 使用關鍵字 function 定義函數。
函數可以通過聲明定義,也可以是一個表達式,函數聲明后不會立即執行,會在我們需要的時候調用到。
函數聲明
語法如下:
function ( 函數名)functionName(parameters(參數)) {
執行的代碼
}
分號是用來分隔可執行JavaScript語句, 由于函數聲明不是一個可執行語句,所以不以分號結束。
函數聲明后不會立即執行,會在我們需要的時候調用到。
函數表達式:
JavaScript 函數可以通過一個表達式定義,函數表達式可以存儲在變量中,在函數表達式存儲在變量后,變量也可作為一個函數使用。
函數存儲在變量中,不需要函數名稱,通常通過變量名來調用,函數實際上是一個 匿名函數 (函數沒有名稱)。
Function() 構造函數:
函數同樣可以通過內置的 JavaScript 函數構造器(Function())定義。
在 JavaScript 中,很多時候,你需要避免使用 new 關鍵字。
函數提升(Hoisting):
提升(Hoisting)是 JavaScript 默認將當前作用域提升到前面去的行為。
提升(Hoisting)應用在變量的聲明與函數的聲明。
因此,函數可以在聲明之前調用:
使用表達式定義函數時無法提升。
自調用函數:
函數表達式可以 "自調用",函數實際上是一個 匿名自我調用的函數 (沒有函數名)。
自調用表達式會自動調用。
如果表達式后面緊跟 () ,則會自動調用。
不能自調用聲明的函數。
通過添加括號,來說明它是一個函數表達式。
JavaScript 函數作為一個值使用:
JavaScript 函數可作為表達式使用
自調用函數語法:(functin(){})()
函數是對象:
在 JavaScript 中使用 typeof 操作符判斷函數類型將返回 "function" 。
但是JavaScript 函數描述為一個對象更加準確。
JavaScript 函數有 屬性 和 方法。
arguments.length 屬性返回函數調用過程接收到的參數個數。
toString() 方法將函數作為一個字符串返回。
函數定義作為對象的屬性,稱之為對象方法,函數如果用于創建新的對象,稱之為對象的構造函數。
函數參數
函數 "顯式參數(Parameters)" 與 "隱式參數(Arguments)"。
顯式參數(Parameters):函數顯式參數在函數定義時列出。
隱式參數(Arguments):函數隱式參數在函數調用時傳遞給函數真正的值。
參數規則:
JavaScript 函數定義時顯式參數沒有指定數據類型。
JavaScript 函數對隱式參數沒有進行類型檢測。
JavaScript 函數對隱式參數的個數沒有進行檢測。
。。。。。。
如果函數在調用時未提供隱式參數,參數會默認設置為: undefined
有時這是可以接受的,但是建議最好為參數設置一個默認值:
如果函數調用時設置了過多的參數,參數將無法被引用,因為無法找到對應的參數名。 只能使用 arguments 對象來調用。
Arguments 對象:
JavaScript 函數有個內置的對象 arguments 對象。
通過這種方式你可以很方便的找到最大的一個參數的值。
通過值傳遞參數:
在函數中調用的參數是函數的隱式參數。
JavaScript 隱式參數通過值來傳遞:函數僅僅只是獲取值。
如果函數修改參數的值,不會修改顯式參數的初始值(在函數外定義)。
隱式參數的改變在函數外是不可見的。
通過對象傳遞參數:
在JavaScript中,可以引用對象的值。
因此我們在函數內部修改對象的屬性就會修改其初始的值。
修改對象屬性可作用于函數外部(全局變量)。
修改對象屬性在函數外是可見的。
JavaScript 函數調用
JavaScript 函數有 4 種調用方式。
每種方式的不同在于 this 的初始化。
this 關鍵字:
一般而言,在Javascript中,this指向函數執行時的當前對象。注意: this 是保留關鍵字,你不能修改 this 的值。
調用 JavaScript 函數,函數中的代碼在函數被調用后執行。
在 HTML 中默認的全局對象是 HTML 頁面本身,所以函數是屬于 HTML 頁面。
在瀏覽器中的頁面對象是瀏覽器窗口(window 對象),myFunction() 和 window.myFunction() 是一樣的。
這是調用 JavaScript 函數常用的方法, 但不是良好的編程習慣 ,全局變量,方法或函數容易造成命名沖突的bug。
全局對象:
當函數沒有被自身的對象調用時 this 的值就會變成全局對象。
在 web 瀏覽器中全局對象是瀏覽器窗口(window 對象)。
函數作為全局對象調用,會使 this 的值成為全局對象,使用 window 對象作為一個變量容易造成程序崩潰。
函數作為方法調用:
在 JavaScript 中你可以將函數定義為對象的方法。
函數作為對象方法調用,會使得 this 的值成為對象本身。
使用構造函數調用函數:
如果函數調用前使用了 new 關鍵字, 則是調用了構造函數。
構造函數的調用會創建一個新的對象。新對象會繼承構造函數的屬性和方法。
構造函數中 this 關鍵字沒有任何的值,this 的值在函數調用實例化對象(new object)時創建。
作為函數方法調用函數:
在 JavaScript 中, 函數是對象。JavaScript 函數有它的屬性和方法。
call() 和 apply() 是預定義的函數方法。 兩個方法可用于調用函數,兩個方法的第一個參數必須是對象本身。
兩個方法都使用了對象本身作為第一個參數。 兩者的區別在于第二個參數: apply傳入的是一個參數數組,也就是將多個參數組合成為一個數組傳入,而call則作為call的參數傳入(從第二個參數開始)。
在 JavaScript 嚴格模式(strict mode)下, 在調用函數時第一個參數會成為 this 的值, 即使該參數不是一個對象。
在 JavaScript 非嚴格模式(non-strict mode)下, 如果第一個參數的值是 null 或 undefined, 它將使用全局對象替代。
通過 call() 或 apply() 方法你可以設置 this 的值, 且作為已存在對象的新方法調用。
this 是 JavaScript 語言的一個關鍵字。它代表函數運行時,自動生成的一個內部對象,只能在函數內部使用。
隨著函數使用場合的不同,this 的值會發生變化。但是有一個總的原則,那就是this指的是,調用函數的那個對象。
JavaScript 閉包
JavaScript 變量可以是局部變量或全局變量,私有變量可以用到閉包,函數可以訪問由函數內部定義的變量。
在web頁面中全局變量屬于 window 對象,全局變量可應用于頁面上的所有腳本。
局部變量只能用于定義它函數內部。對于其他的函數或腳本代碼是不可用的。
全局和局部變量即便名稱相同,它們也是兩個不同的變量。修改其中一個,不會影響另一個的值。
變量聲明時如果不使用 var 關鍵字,那么它就是一個全局變量,即便它在函數內定義。
變量生命周期:
全局變量的作用域是全局性的,即在整個JavaScript程序中,全局變量處處都在。
而在函數內部聲明的變量,只在函數內部起作用。這些變量是局部變量,作用域是局部性的;函數的參數也是局部性的,只在函數內部起作用。
計數器困境:
設想下如果你想統計一些數值,且該計數器在所有函數中都是可用的,你可以使用全局變量,函數設置計數器遞增。
JavaScript 內嵌函數:
所有函數都能訪問全局變量。
實際上,在 JavaScript 中,所有函數都能訪問它們上一層的作用域。
JavaScript 支持嵌套函數。嵌套函數可以訪問上一層的函數變量。
閉包是可訪問上一層函數作用域里變量的函數,即便上一層函數已經關閉。
感謝各位的閱讀,以上就是“javascript中的函數知識點有哪些”的內容了,經過本文的學習后,相信大家對javascript中的函數知識點有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。