函數(shù)是由事件驅動的或者當它被調用時執(zhí)行的可重復使用的代碼塊。本文重點給大家介紹js基礎知識盲點總結之函數(shù)。
一、函數(shù)中的arguments對象
每個函數(shù)內部都有一個arguments,它能返回函數(shù)所接受的所有參數(shù)
注意:argumens接收的是實參
如下是利一個利用arguments特性編寫的求和函數(shù):
function sumOnSteroids(){
var I, res = 0;
var number_of_params = arguments.length;
for(I = 0; I < number_of_params; i++){
res += arguments[i];
}
return res;
}
二、關于變量的作用域
在javascript中,不能為變量定義特定的塊級作用域,但是可以定義其所屬的函數(shù)域。
javascript中的全局變量指的是聲明在所有函數(shù)之外的變量
在一個函數(shù)內部定義的局部變量,在函數(shù)外部是不存在的
如果在函數(shù)內部聲明一個變量時沒有使用var語句,該變量就會被默認為全局變量(即便在函數(shù)中定義外部也可以訪問)。這種變量會在函數(shù)被調用之前不存在,調用函數(shù)后會首次被創(chuàng)建并賦予全局作用域
三、自調函數(shù)
自調函數(shù)是可以在定義后自行調用的函數(shù),基本結構如下:
{
function(name){
alert(‘Hello' + name + ‘!');
}
}(‘Martin')
后面的()可以進行參數(shù)傳遞,其內聲明的值會自動傳遞到function的參數(shù)中
使用如上這種自調匿名函數(shù)不會產(chǎn)生任何的全局變量
四、可自行重寫的函數(shù)
這種函數(shù)的特點是可以在執(zhí)行之后自己進行函數(shù)重寫,下面是一個例子:
function a(){
alert(“A”);
a = function(){
alert(“B”)
};
}
第一次調用a()時,執(zhí)行alert(“A”);第二次調用a()時,執(zhí)行alert(“B”)。因為在第一次執(zhí)行該函數(shù)時,其將全局變量a重新定義了
以上所述是小編給大家介紹的Javascript基礎知識盲點總結之函數(shù)的相關知識,希望對大家以上幫助!