js 立即調用的函數(shù)表達式如何寫
更新時間:2014年01月12日 17:39:14 作者:
如果不需要顯示調用函數(shù), 讓這個函數(shù)在定義的時候就執(zhí)行的話, 該如何寫才可以呢,下面為大家介紹下具體的實現(xiàn)步驟,喜歡的朋友可以了解下
如果不需要顯示調用函數(shù), 讓這個函數(shù)在定義的時候就執(zhí)行的話, 該如何寫才可以呢,接下來將詳細介紹實現(xiàn)步驟,感興趣的朋友可以了解下
1.前言
函數(shù)需要先定義,后使用。 這基本上所有編程語言的一條鐵的定律。
一般狀況下, 我們需要調用一個JavaScript 函數(shù), 基本的狀況都是先定義, 然后再調用。 看一個例子
代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Say Hello</title>
</head>
<body>
<script>
//define function
function sayHello()
{
alert("hello");
}
//call function
sayHello();
</script>
</body>
</html>
但是如果不需要顯示調用函數(shù), 讓這個函數(shù)在定義的時候就執(zhí)行的話, 該如何寫才可以呢?
2.思考的歷程
從以上的例子來看,聰明的你結合以上的使用狀況可能會想:
===》既然調用的時候是在函數(shù)名后面加上一對 是否在function 定義的后面加上一對大括號是否就可以執(zhí)行了呢? 像以下這樣:
代碼如下:
function sayHello()
{
alert("hello");
}();
不幸的是,以上的寫法會報出js 的語法錯誤。
因為Javascript 的解析器在解析器解析全局的function或者function內部function關鍵字的時候, 默認會把大括號解析成function聲明,而不是function表達式。
也就是說, 會把最后的一對大括號默認解析成一個缺少名字的function,并且拋出一個語法錯誤信息,因為function聲明需要一個名字。
===》 你可能又會想, 如果我在大括號中傳入?yún)?shù)是否就會解析成表達式了呢?
代碼如下:
function sayHello()
{
alert("hello");
}(1);
的確, 錯誤是沒有了。 但是以上的寫法等同于以下寫法的效果
代碼如下:
function sayHello()
{
alert("hello");
};
(1);
這兩句完全沒有關系, 函數(shù)還是不會執(zhí)行
3.正確的寫法
對于JavaScript 來說,括弧()里面不能包含語句,所以在這一點上,解析器在解析function關鍵字的時候,會將相應的代碼解析成function表達式,而不是function聲明所以,只要將大括號將代碼(包括函數(shù)部分和在后面加上一對大括號)全部括起來就可以了。
代碼如下:
(function sayHello()
{
alert("hello");
}());
還有一種寫法也可以, 就是將后面的大括號移出來, as
代碼如下:
(function sayHello()
{
alert("hello");
})();
推薦是使用第一種方式。
但是目前很多比較好的js library 使用的都是第二種方式。
比如: web 圖形繪制的: git , draw2d ,....
1.前言
函數(shù)需要先定義,后使用。 這基本上所有編程語言的一條鐵的定律。
一般狀況下, 我們需要調用一個JavaScript 函數(shù), 基本的狀況都是先定義, 然后再調用。 看一個例子
代碼如下:
復制代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Say Hello</title>
</head>
<body>
<script>
//define function
function sayHello()
{
alert("hello");
}
//call function
sayHello();
</script>
</body>
</html>
但是如果不需要顯示調用函數(shù), 讓這個函數(shù)在定義的時候就執(zhí)行的話, 該如何寫才可以呢?
2.思考的歷程
從以上的例子來看,聰明的你結合以上的使用狀況可能會想:
===》既然調用的時候是在函數(shù)名后面加上一對 是否在function 定義的后面加上一對大括號是否就可以執(zhí)行了呢? 像以下這樣:
代碼如下:
復制代碼 代碼如下:
function sayHello()
{
alert("hello");
}();
不幸的是,以上的寫法會報出js 的語法錯誤。
因為Javascript 的解析器在解析器解析全局的function或者function內部function關鍵字的時候, 默認會把大括號解析成function聲明,而不是function表達式。
也就是說, 會把最后的一對大括號默認解析成一個缺少名字的function,并且拋出一個語法錯誤信息,因為function聲明需要一個名字。
===》 你可能又會想, 如果我在大括號中傳入?yún)?shù)是否就會解析成表達式了呢?
代碼如下:
復制代碼 代碼如下:
function sayHello()
{
alert("hello");
}(1);
的確, 錯誤是沒有了。 但是以上的寫法等同于以下寫法的效果
代碼如下:
復制代碼 代碼如下:
function sayHello()
{
alert("hello");
};
(1);
這兩句完全沒有關系, 函數(shù)還是不會執(zhí)行
3.正確的寫法
對于JavaScript 來說,括弧()里面不能包含語句,所以在這一點上,解析器在解析function關鍵字的時候,會將相應的代碼解析成function表達式,而不是function聲明所以,只要將大括號將代碼(包括函數(shù)部分和在后面加上一對大括號)全部括起來就可以了。
代碼如下:
復制代碼 代碼如下:
(function sayHello()
{
alert("hello");
}());
還有一種寫法也可以, 就是將后面的大括號移出來, as
代碼如下:
復制代碼 代碼如下:
(function sayHello()
{
alert("hello");
})();
推薦是使用第一種方式。
但是目前很多比較好的js library 使用的都是第二種方式。
比如: web 圖形繪制的: git , draw2d ,....
相關文章
ie6下png圖片背景不透明的解決辦法使用js實現(xiàn)
我們時常在使用png圖片的時候,在ie6下發(fā)生背景不透明的問題,解決的方法實在是太多了,下面給大家介紹下一個js解決的方式,感興趣的朋友可以了解下的2013-01-01
使用JavaScript實現(xiàn)一個靜態(tài)鏈表
這篇文章主要為大家詳細介紹了如何使用JavaScript實現(xiàn)一個靜態(tài)鏈表,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以跟隨小編一起了解一下2023-06-06

