中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS立即執行函數功能與用法分析

發布時間:2020-09-05 21:00:37 來源:腳本之家 閱讀:147 作者:Yu丶 欄目:web開發

本文實例講述了JS立即執行函數功能與用法。分享給大家供大家參考,具體如下:

相信大家經常會遇到下面這兩種寫法:

(function(){ ... })()

(function(){ ... }())

關于這樣寫是什么意思呢?有什么區別呢?

在此之前,我們需要了解幾個概念:

函數聲明函數表達式匿名函數

函數聲明: function fnName() {...} ;

使用 function 關鍵字聲明一個函數,再執行一個函數名,叫函數聲明。

函數表達式: var fnName = function() { ... } ;

使用 function 關鍵字聲明一個函數,但未給函數命名,最后將匿名函數賦予一個變量,叫函數表達式,這是最常見的函數表達式語法形式。

匿名函數: function() { ... } ;

使用 function 關鍵字聲明一個函數,但未給函數命名,所以叫匿名函數,匿名函數屬于函數表達式,匿名函數有很多作用,賦予一個變量則創建函數,賦予一個事件則成為事件處理程序或創建閉包等等。

函數聲明和函數表達式不同之處在于

1、JavaScript 引擎在解析 JavaScript 代碼時會“函數聲明提升”當前執行環境(作用域)上的函數聲明,而函數表達式必須等到 JavaScript 引擎執行到它所在行時,才會從上而下一行一行地解析函數表達式。

2、函數表達式后面可以加括號立即調用該函數,函數聲明不可以,只能以 fnName() 形式調用。

知道了這些函數基本概念后,回頭看看 (function(){ ... }()) (function() { ... })() 這兩種立即執行函數的寫法,最初我以為是一個括號包裹匿名函數,并在后面加個括號立即調用函數,當時不知道為什么要加括號,后來明白,要在函數體后面加括號就能立即調用,則這個函數必須是函數表達式,不能是函數聲明。

(function(a) {
 console.log(a); //使用()運算符,打印出123
})(123);
(function(a) {
 console.log(a); //使用()運算符,打印出1234
}(1234));
!function(a) {
 console.log(a); //使用!運算符,打印出12345
}(12345);
+function(a) {
 console.log(a); //使用+運算符,打印出123456
}(123456);
-function(a) {
 console.log(a); //使用-運算符,打印出1234567
}(1234567);
var fn = function(a) {
 console.log(a); //使用=運算符,打印出12345678
}(12345678);

可以看到輸出結果,在 function 前面加 ! 、+ 、- 甚至是逗號等都可以起到函數定以后立即執行的效果,而 () 、! 、+ 、- 、= 等運算符,都將函數聲明轉換成函數表達式,消除了 javascript 引擎識別函數表達式和函數聲明的歧義,告訴 javascript 引擎這是一個函數表達式,不是函數聲明,可以在后面加括號,并立即執行函數的代碼。

加括號是最安全的做法,因為 ! 、+ 、- 等運算符還會和函數的返回值進行運算,有時造成不必要的麻煩。

不過這樣的寫法有什么用呢?

javascript 中沒有私有作用域的概念,如果在多人開發的項目上,你在全局或局部作用域中聲明了一些變量,可能會被其他人不小心用同名的變量給覆蓋掉,根據 javascript 函數作用域鏈的特性,可以使用這種技術可以模仿一個私有作用域,用匿名函數作為一個“容器”,“容器”內部可以訪問外部的變量,而外部環境不能訪問“容器”內部的變量,所以 (function(){ ... })() 內部定義的變量不會和外部的變量發生沖突,俗稱“匿名包裹器”或“命名空間”。

jQuery 使用的就是這種方法,將 jQuery 代碼包裹在 (function(window,undefined){ ...jquery代碼...})(window) 中,在全局作用域中調用 jQuery 代碼時,可以達到保護 jQuery 內部變量的作用。

更多關于JavaScript相關內容可查看本站專題:《JavaScript常用函數技巧匯總》、《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

德安县| 宁海县| 道孚县| 张家川| 吉安市| 安丘市| 化德县| 新绛县| 铜山县| 抚顺市| 佛学| 西平县| 延寿县| 博湖县| 新津县| 太和县| 商南县| 罗源县| 苍溪县| 黄骅市| 溆浦县| 南江县| 霍城县| 宁河县| 南通市| 乌海市| 绍兴县| 泰兴市| 运城市| 邢台县| 长治县| 苗栗县| 星座| 乡城县| 兰考县| 萝北县| 古浪县| 巩义市| 齐齐哈尔市| 特克斯县| 天等县|