標籤:不能 返回 def 引擎 arguments 原始類型 函數的參數 EAP 表示
函數的概念
1)函數的基本概念和建立方式
建立:
function zxw(a){ console.log(a);}
function後面接函數的名字,圓括弧是要傳入函數的參數,函數體在大括弧裡。
var zxw = function(a){ console.log(a);}
這是用變數賦值的寫法將匿名函數賦值給變數,如果在加上了函數名,那隻有在這函數體內部有效,函數體外部是無效的。
調用和return語句:
要調用函數時,寫上函數名後面在加圓括弧就可以調用了
function add(a,b){ return a+b;}add(1,2)
上面函數圓括弧內裡的就是這個函數的參數,在調用add這個函數時將數值1和2帶入進去。
函數體內部的return語句表示的是返回,當JavaScript遇到這個語句,就直接返回這個語句後面的值,就算後面還有語句也不會執行。return語句所帶的那個運算式就是函數的傳回值,如果沒有return語句那這個函數就不會有任何輸出,返回的是undefined。
函數可以自己調用自己,這個就叫遞迴。
2)函數名提升
JavaScript 引擎將函數名視同變數名,在用function命令聲明函數時,整個函數會像變數聲明一樣,被提升到代碼頭部:
f();function zxw(){ console.log(‘zxw‘);}
雖然先執行了f函數,但由於函數提升,函數f被提升到了代碼頭部,所以在被調用前就聲明了。
只有用函式宣告的方式才存在函數提升,如果用函數運算式的方式,JavaScript就會報錯。
f1();var f1 = function(){} //undefined
3)參數
傳遞方式:
JavaScript中資料類型一般分為2類:
- 原始類型:儲存在棧(stack)中的簡單的資料,它們的值直接儲存在變數訪問的位置。
- 參考型別:儲存在堆(heap)中的對象,儲存在變數處的值是一個指標(point),指向儲存物件的記憶體位址。
這2種記憶體配置機制也導致傳遞參數的方式也不同
- 傳入的參數為原始類型:只是把變數的值傳遞給參數,後面無論怎麼修改參數和變數都不會互相影響。
- 傳入的參數為參考型別:當傳入的參數是參考型別的時,此時傳入函數的是原始值的地址,因為物件變數它裡面的值是這個對象在堆記憶體中的記憶體位址,所以在函數內部修改參數的話就會影響到原始值。
arguments對象:
說起參數,還要說到arguments對象,它可以讀取函數體內部的所有參數
function f(d){ console.log(arguments); //函數參數的集合 console.log(arguments.length); //傳遞參數的個數}
arguments對象的格式很想數組,但它不是數組,所以數組的方法不能用在arguments對象上
總結下,函數在JavaScript中作為第一等公民,它被看做一種值,凡是可以使用值的地方就可以使用函數。我們可以將函數賦值給對象或對象的屬性,也可以當做參數傳入其他函數,或者作為函數的結果返回。
JS函數概念