Javascript基礎(chǔ)知識盲點總結(jié)之函數(shù)
函數(shù)是由事件驅(qū)動的或者當(dāng)它被調(diào)用時執(zhí)行的可重復(fù)使用的代碼塊。本文重點給大家介紹js基礎(chǔ)知識盲點總結(jié)之函數(shù)。
一、函數(shù)中的arguments對象
每個函數(shù)內(nèi)部都有一個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;
}
二、關(guān)于變量的作用域
在javascript中,不能為變量定義特定的塊級作用域,但是可以定義其所屬的函數(shù)域。
javascript中的全局變量指的是聲明在所有函數(shù)之外的變量
在一個函數(shù)內(nèi)部定義的局部變量,在函數(shù)外部是不存在的
如果在函數(shù)內(nèi)部聲明一個變量時沒有使用var語句,該變量就會被默認(rèn)為全局變量(即便在函數(shù)中定義外部也可以訪問)。這種變量會在函數(shù)被調(diào)用之前不存在,調(diào)用函數(shù)后會首次被創(chuàng)建并賦予全局作用域
三、自調(diào)函數(shù)
自調(diào)函數(shù)是可以在定義后自行調(diào)用的函數(shù),基本結(jié)構(gòu)如下:
{
function(name){
alert(‘Hello' + name + ‘!');
}
}(‘Martin')
后面的()可以進行參數(shù)傳遞,其內(nèi)聲明的值會自動傳遞到function的參數(shù)中
使用如上這種自調(diào)匿名函數(shù)不會產(chǎn)生任何的全局變量
四、可自行重寫的函數(shù)
這種函數(shù)的特點是可以在執(zhí)行之后自己進行函數(shù)重寫,下面是一個例子:
function a(){
alert(“A”);
a = function(){
alert(“B”)
};
}
第一次調(diào)用a()時,執(zhí)行alert(“A”);第二次調(diào)用a()時,執(zhí)行alert(“B”)。因為在第一次執(zhí)行該函數(shù)時,其將全局變量a重新定義了
以上所述是小編給大家介紹的Javascript基礎(chǔ)知識盲點總結(jié)之函數(shù)的相關(guān)知識,希望對大家以上幫助!
相關(guān)文章
js剪切板應(yīng)用clipboardData實例解析
這篇文章主要為大家詳細(xì)介紹了js剪切板應(yīng)用clipboardData實例,并分享了四種實現(xiàn)方法,感興趣的小伙伴們可以參考一下2016-05-05
JS實現(xiàn)的倒計時恢復(fù)按鈕點擊功能【可用于協(xié)議閱讀倒計時】
這篇文章主要介紹了JS實現(xiàn)的倒計時恢復(fù)按鈕點擊功能,可用于協(xié)議閱讀倒計時,涉及javascript基于setInterval的時間定時觸發(fā)相關(guān)操作技巧,需要的朋友可以參考下2018-04-04
EasyUI彈出框行編輯如何通過下拉框?qū)崿F(xiàn)內(nèi)容聯(lián)動
本文介紹了如何使用EasyUI彈出框和下拉框?qū)崿F(xiàn)內(nèi)容聯(lián)動,并詳細(xì)描述了當(dāng)用戶選擇下拉框時如何更新當(dāng)前行數(shù)據(jù),通過解決datagrid的onClickRow和onClickCell事件不觸發(fā)的問題,實現(xiàn)了下拉框選擇后數(shù)據(jù)的自動填充2024-11-11
js加載之使用DOM方法動態(tài)加載Javascript文件
傳統(tǒng)上,加載Javascript文件都是使用script標(biāo)簽,我們也可以使用DOM方法,動態(tài)加載Javascript文件,具體實現(xiàn)如下,感興趣的朋友可以參考下2013-11-11

