JavaScript 定義function的三種方式小結
更新時間:2009年10月16日 22:16:52 作者:
JavaScript中定義function有以下三種方式.
(1)聲明一個表達式變量,并定義該變量的表達式。如:
var func = function()
{
/*body code*/
}
(2) 定義一個function表達式,并指定該表達式的標識。如:
function func()
{
//body code
}
(3) 使用JavaScript內(nèi)置Function對象構造。如:
var func = new Function("/*parameters*/","/*body code*/");
聲明變量定義與使用function表達式標識定義是有區(qū)別的。我們知道,function在發(fā)生傳遞時采用的是引用傳遞類型,使用變量定義是保存了表達式的地址引用,而使用標志定義保存了表達式的地址。因此當我們改變或重新定義變量時,并不會導致原來的表達式改變;而當改變標識時,其對應的表達式也隨之改變。如:
//聲明一個變量,并定義該變量的表達式引用
var test = function()
{
alert("reference test");
}
//定義一個表達式,保存其地址信息于test1中
function test1()
{
alert("reference test1");
}
//將test所引用的表達式傳遞給reference
var reference = test;
//將test1表達式的地址傳遞給reference1
var reference1 = test1;
//改變變量test的引用
test = function()
{
alert("new test");
}
//重新定義test1地址內(nèi)的數(shù)據(jù)
function test1()
{
alert("new test1");
}
alert(reference);//其所引用的表達式不改變
alert(reference1);//由于reference1是test1地址的引用,當test1地址表示的內(nèi)容改變時,reference1的內(nèi)容也隨之改變
復制代碼 代碼如下:
var func = function()
{
/*body code*/
}
(2) 定義一個function表達式,并指定該表達式的標識。如:
復制代碼 代碼如下:
function func()
{
//body code
}
(3) 使用JavaScript內(nèi)置Function對象構造。如:
復制代碼 代碼如下:
var func = new Function("/*parameters*/","/*body code*/");
聲明變量定義與使用function表達式標識定義是有區(qū)別的。我們知道,function在發(fā)生傳遞時采用的是引用傳遞類型,使用變量定義是保存了表達式的地址引用,而使用標志定義保存了表達式的地址。因此當我們改變或重新定義變量時,并不會導致原來的表達式改變;而當改變標識時,其對應的表達式也隨之改變。如:
復制代碼 代碼如下:
//聲明一個變量,并定義該變量的表達式引用
var test = function()
{
alert("reference test");
}
//定義一個表達式,保存其地址信息于test1中
function test1()
{
alert("reference test1");
}
//將test所引用的表達式傳遞給reference
var reference = test;
//將test1表達式的地址傳遞給reference1
var reference1 = test1;
//改變變量test的引用
test = function()
{
alert("new test");
}
//重新定義test1地址內(nèi)的數(shù)據(jù)
function test1()
{
alert("new test1");
}
alert(reference);//其所引用的表達式不改變
alert(reference1);//由于reference1是test1地址的引用,當test1地址表示的內(nèi)容改變時,reference1的內(nèi)容也隨之改變
相關文章
javascript時間排序算法實現(xiàn)活動秒殺倒計時效果
這篇文章主要介紹了javascript時間排序算法實現(xiàn)活動秒殺倒計時效果,即一個頁面多個倒計時排序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-03-03javascript 身份證號碼驗證函數(shù)(可辨真?zhèn)?,支?5或18位身份證號)測試誤差為0
javascript 身份證號碼驗證函數(shù)(可辨真?zhèn)?,支?5或18位身份證號)測試誤差為0 ,非常不錯,其實主要是特別熟悉身份證的算法。2010-05-05JS動態(tài)添加與刪除select中的Option對象(示例代碼)
本篇文章主要介紹了JS動態(tài)添加與刪除select中的Option對象示例代碼。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12JavaScript面試Module?Federation實現(xiàn)原理詳解
這篇文章主要為大家介紹了JavaScript面試Module?Federation實現(xiàn)原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10JS實現(xiàn)可縮放、拖動、關閉和最小化的浮動窗口完整實例
這篇文章主要介紹了JS實現(xiàn)可縮放、拖動、關閉和最小化的浮動窗口的方法,實例分析了javascript操作窗口層的技巧,需要的朋友可以參考下2015-03-03