for(var i=0;i=3;i++){ setTimeout(function() { console.log(i) }, 10);}

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供會昌網(wǎng)站建設(shè)、會昌做網(wǎng)站、會昌網(wǎng)站設(shè)計、會昌網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、會昌企業(yè)網(wǎng)站模板建站服務,十余年會昌做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
答案:打印4次4
這道題涉及了異步、作用域、閉包
settimeout是異步執(zhí)行,10ms后往任務隊列里面添加一個任務,只有主線上的全部執(zhí)行完,才會執(zhí)行任務隊列里的任務,當主線執(zhí)行完成后,i是4,所以此時再去執(zhí)行任務隊列里的任務時,i全部是4了。對于打印4次是:
每一次for循環(huán)的時候,settimeout都執(zhí)行一次,但是里面的函數(shù)沒有被執(zhí)行,而是被放到了任務隊列里面,等待執(zhí)行,for循環(huán)了4次,就放了4次,當主線程執(zhí)行完成后,才進入任務隊列里面執(zhí)行。
(注意:for循環(huán)從開始到結(jié)束的過程,需要維持幾微秒或幾毫秒。)
當我把var 變成let 時
for(let i=0;i=3;i++){ setTimeout(function() { console.log(i) }, 10);}
打印出的是:0,1,2,3
當解決變量作用域,
因為for循環(huán)頭部的let不僅將i綁定到for循環(huán)快中,事實上它將其重新綁定到循環(huán)體的每一次迭代中,確保上一次迭代結(jié)束的值重新被賦值。setTimeout里面的function()屬于一個新的域,通過 var 定義的變量是無法傳入到這個函數(shù)執(zhí)行域中的,通過使用 let 來聲明塊變量,這時候變量就能作用于這個塊,所以 function就能使用 i 這個變量了;這個匿名函數(shù)的參數(shù)作用域 和 for參數(shù)的作用域 不一樣,是利用了這一點來完成的。這個匿名函數(shù)的作用域有點類似類的屬性,是可以被內(nèi)層方法使用的。
查了一下百度的一個答案:
setTimeout是一次執(zhí)行函數(shù),這里是10ms后執(zhí)行,僅僅執(zhí)行一次;for(var i=0;i=3;i++),i的每次取值都是執(zhí)行setTimeout這個函數(shù),并沒有執(zhí)行setTimeout里面的function(即閉包函數(shù)),setTimeout里面的function是有setTimeout的定時觸動的,也就是10ms后執(zhí)行,也就是說i從0~3時,一共執(zhí)行了4次的setTimeout()函數(shù),此時的i的值是4,由于for語句的執(zhí)行速度遠小于1秒,所以,1秒后,由setTimeout()函數(shù)定時觸動的閉包函數(shù)function()開始執(zhí)行,alert(i);i的值已經(jīng)是4了,所以相繼打印4次i.
匿名函數(shù):定義時未定義函數(shù)的名稱
閉包: 創(chuàng)建時封裝周圍狀態(tài)的函數(shù),及時周圍的環(huán)境不存在了,閉包中的狀態(tài)還會存在
從理論上講 匿名函數(shù)和閉包屬于兩種概念,PHP中視為相同
1.非匿名函數(shù)在定義時就創(chuàng)建函數(shù)對象和作用域?qū)ο蟆R院蠹皶r未調(diào)用,也占空間
2.匿名函數(shù)只有在調(diào)用時,才會創(chuàng)建函數(shù)對象和作用域?qū)ο蟆U{(diào)用完后立即釋放,節(jié)省內(nèi)存。適合做回調(diào)函數(shù)
javascript中: (function(){})()是匿名函數(shù),主要利用函數(shù)內(nèi)的變量作用域,避免產(chǎn)生全局變量,影響整體頁面環(huán)境,增加代碼的兼容性。
(function(){})是一個標準的函數(shù)定義,但是沒有復制給任何變量。所以是沒有名字的函數(shù),叫匿名函數(shù)。沒有名字就無法像普通函數(shù)那樣隨時隨地調(diào)用了,所以在他定義完成后就馬上調(diào)用他,后面的括號()是運行這個函數(shù)的意思
擴展資料
函數(shù)聲明:使用function聲明函數(shù),并指定函數(shù)名。
function setFn() { ? ?// coding ? }
函數(shù)表達式:使用function聲明函數(shù),但未指定函數(shù)名,將匿名函數(shù)賦予一個變量。
var setFn = function() { ? ?// coding}
匿名函數(shù):使用function關(guān)鍵字聲明函數(shù),但未指定函數(shù)名。匿名函數(shù)屬于函數(shù)表達式,匿名函數(shù)有很多作用,賦予一個變量則創(chuàng)建函數(shù),賦予一個事件則成為事件處理程序或創(chuàng)建閉包等等。
function() { ? ?// coding}
參考資料:百度百科 - javascript
函數(shù)的另外一種表現(xiàn)形式,還是函數(shù),只適用于函數(shù)功能比較簡單的函數(shù)(聲明的格式和普通的函數(shù)不一樣)
就是變量能夠使用的范圍
a = 520
在函數(shù)中:
global 變量名
變量名 = 值
語法:
nonlocal 局部變量
局部變量 = 值
python中聲明函數(shù)其實就是聲明一個數(shù)據(jù)是function的變量,函數(shù)名就是變量名
對比如下:
變量作為函數(shù)的返回值
函數(shù)1作為函數(shù)2的返回值 - 函數(shù)2是返回值高階函數(shù)
//作用域和匿名函數(shù)沒用任何關(guān)系
//js中函數(shù)內(nèi)的變量在函數(shù)內(nèi)的任何地方都能訪問
//window對象下定義的變量均為全局變量,如:
var?i?=?1;????//這個變量就是全局變量
function?fun(){
var?j?=?1;????//這個j是局部變量,在fun里面的任何地方都能訪問
}
//說匿名函數(shù)
$(function(){
//這個function(){}就是匿名函數(shù)
});
var?fun1?=?function(){
//這個function(){}也是匿名函數(shù)
}
//論匿名函數(shù)的重要性
//js中的匿名函數(shù)的重要性不亞于三元運算
//不過js中任何能用匿名函數(shù)實現(xiàn)的代碼用普通函數(shù)都能實現(xiàn)
//就好比任何三元運算都能用if實現(xiàn)一樣
$("body").click(function(){
//jquery最基本的綁定click事件的一種
});
//上面這里用的就是匿名函數(shù),可以用下面的代碼代替
function?clickHandle(){
}
$("body").click(clickHandle);
//說自運行函數(shù)
(function(){
//這里還是匿名函數(shù)
})();
//上面的自運行函數(shù)(閉包操作)可以改成下面這樣
function?tempFun(){
}
tempFun();
//有幫助的話麻煩采納下,手打不易,謝謝!
網(wǎng)頁標題:c語言匿名函數(shù)的作用域 什么函數(shù)也稱為匿名函數(shù)
本文路徑:http://chinadenli.net/article46/doogghg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、企業(yè)網(wǎng)站制作、標簽優(yōu)化、云服務器、域名注冊、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)