欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js 立即調(diào)用的函數(shù)表達(dá)式如何寫

 更新時(shí)間:2014年01月12日 17:39:14   作者:  
如果不需要顯示調(diào)用函數(shù), 讓這個(gè)函數(shù)在定義的時(shí)候就執(zhí)行的話, 該如何寫才可以呢,下面為大家介紹下具體的實(shí)現(xiàn)步驟,喜歡的朋友可以了解下
如果不需要顯示調(diào)用函數(shù), 讓這個(gè)函數(shù)在定義的時(shí)候就執(zhí)行的話, 該如何寫才可以呢,接下來(lái)將詳細(xì)介紹實(shí)現(xiàn)步驟,感興趣的朋友可以了解下

1.前言
函數(shù)需要先定義,后使用。 這基本上所有編程語(yǔ)言的一條鐵的定律。
一般狀況下, 我們需要調(diào)用一個(gè)JavaScript 函數(shù), 基本的狀況都是先定義, 然后再調(diào)用。 看一個(gè)例子
代碼如下:
復(fù)制代碼 代碼如下:

<!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>

但是如果不需要顯示調(diào)用函數(shù), 讓這個(gè)函數(shù)在定義的時(shí)候就執(zhí)行的話, 該如何寫才可以呢?

2.思考的歷程
從以上的例子來(lái)看,聰明的你結(jié)合以上的使用狀況可能會(huì)想:
===》既然調(diào)用的時(shí)候是在函數(shù)名后面加上一對(duì) 是否在function 定義的后面加上一對(duì)大括號(hào)是否就可以執(zhí)行了呢? 像以下這樣:
代碼如下:
復(fù)制代碼 代碼如下:

function sayHello()
{
alert("hello");
}();

不幸的是,以上的寫法會(huì)報(bào)出js 的語(yǔ)法錯(cuò)誤。
因?yàn)镴avascript 的解析器在解析器解析全局的function或者function內(nèi)部function關(guān)鍵字的時(shí)候, 默認(rèn)會(huì)把大括號(hào)解析成function聲明,而不是function表達(dá)式。

也就是說(shuō), 會(huì)把最后的一對(duì)大括號(hào)默認(rèn)解析成一個(gè)缺少名字的function,并且拋出一個(gè)語(yǔ)法錯(cuò)誤信息,因?yàn)閒unction聲明需要一個(gè)名字。

===》 你可能又會(huì)想, 如果我在大括號(hào)中傳入?yún)?shù)是否就會(huì)解析成表達(dá)式了呢?
代碼如下:
復(fù)制代碼 代碼如下:

function sayHello()
{
alert("hello");
}(1);

的確, 錯(cuò)誤是沒(méi)有了。 但是以上的寫法等同于以下寫法的效果
代碼如下:
復(fù)制代碼 代碼如下:

function sayHello()
{
alert("hello");
};
(1);

這兩句完全沒(méi)有關(guān)系, 函數(shù)還是不會(huì)執(zhí)行

3.正確的寫法
對(duì)于JavaScript 來(lái)說(shuō),括弧()里面不能包含語(yǔ)句,所以在這一點(diǎn)上,解析器在解析function關(guān)鍵字的時(shí)候,會(huì)將相應(yīng)的代碼解析成function表達(dá)式,而不是function聲明所以,只要將大括號(hào)將代碼(包括函數(shù)部分和在后面加上一對(duì)大括號(hào))全部括起來(lái)就可以了。
代碼如下:
復(fù)制代碼 代碼如下:

(function sayHello()
{
alert("hello");
}());

還有一種寫法也可以, 就是將后面的大括號(hào)移出來(lái), as
代碼如下:
復(fù)制代碼 代碼如下:

(function sayHello()
{
alert("hello");
})();

推薦是使用第一種方式。
但是目前很多比較好的js library 使用的都是第二種方式。
比如: web 圖形繪制的: git , draw2d ,....

相關(guān)文章

  • ie6下png圖片背景不透明的解決辦法使用js實(shí)現(xiàn)

    ie6下png圖片背景不透明的解決辦法使用js實(shí)現(xiàn)

    我們時(shí)常在使用png圖片的時(shí)候,在ie6下發(fā)生背景不透明的問(wèn)題,解決的方法實(shí)在是太多了,下面給大家介紹下一個(gè)js解決的方式,感興趣的朋友可以了解下的
    2013-01-01
  • js判斷文件格式及大小的簡(jiǎn)單實(shí)例(必看)

    js判斷文件格式及大小的簡(jiǎn)單實(shí)例(必看)

    下面小編就為大家?guī)?lái)一篇js判斷文件格式及大小的簡(jiǎn)單實(shí)例(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • 微信小程序如何訪問(wèn)公眾號(hào)文章

    微信小程序如何訪問(wèn)公眾號(hào)文章

    這篇文章主要介紹了微信小程序如何訪問(wèn)公眾號(hào)文章,隨著小程序不斷的發(fā)展,現(xiàn)在個(gè)人的小程序也開(kāi)放了很多功能了,個(gè)人小程序直接打開(kāi)公眾號(hào)鏈接。在群里看到的一款小程序,點(diǎn)擊可以直接閱讀文章了,需要的朋友可以參考下
    2019-07-07
  • 使用JavaScript實(shí)現(xiàn)一個(gè)靜態(tài)鏈表

    使用JavaScript實(shí)現(xiàn)一個(gè)靜態(tài)鏈表

    這篇文章主要為大家詳細(xì)介紹了如何使用JavaScript實(shí)現(xiàn)一個(gè)靜態(tài)鏈表,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-06-06
  • JavaScript如何輸出楊輝三角

    JavaScript如何輸出楊輝三角

    這篇文章主要介紹了JavaScript如何輸出楊輝三角問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • JavaScript解決Joseph問(wèn)題

    JavaScript解決Joseph問(wèn)題

    JavaScript解決Joseph問(wèn)題...
    2007-02-02
  • Javascript優(yōu)化技巧之短路表達(dá)式詳細(xì)介紹

    Javascript優(yōu)化技巧之短路表達(dá)式詳細(xì)介紹

    這篇文章主要介紹了Javascript優(yōu)化技巧之短路表達(dá)式詳細(xì)介紹,本文講解了什么是短路表達(dá)式,并給出了一些示例,需要的朋友可以參考下
    2015-03-03
  • JavaScript獲取文本框內(nèi)選中文本的方法

    JavaScript獲取文本框內(nèi)選中文本的方法

    這篇文章主要介紹了JavaScript獲取文本框內(nèi)選中文本的方法,實(shí)例分析了javascript通過(guò)onclick獲取文本框選中文本的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • 詳解json串反轉(zhuǎn)義(消除反斜杠)

    詳解json串反轉(zhuǎn)義(消除反斜杠)

    這篇文章主要介紹了詳解json串反轉(zhuǎn)義(消除反斜杠),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 深入理解 JavaScript 中的 JSON

    深入理解 JavaScript 中的 JSON

    我們先來(lái)看一個(gè)JS中常見(jiàn)的JS對(duì)象序列化成JSON字符串的問(wèn)題,請(qǐng)問(wèn),以下JS對(duì)象通過(guò)JSON.stringify后的字符串是怎樣的
    2017-04-04

最新評(píng)論