<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        解析JavaScript循環(huán)和作用域之間的關系(附代碼)

        來源:懂視網 責編:小采 時間:2020-11-27 19:31:08
        文檔

        解析JavaScript循環(huán)和作用域之間的關系(附代碼)

        解析JavaScript循環(huán)和作用域之間的關系(附代碼):我們在工作中經常會用到JavaScript,他與我們的工作有密切的關系。但是JavaScript有一個特點,也許會讓開發(fā)者頭痛, 是其循環(huán)和作用域相關的,那接下里就說說他們之間的關系。舉個例子:const operations = [] for (var i = 0; i < 5
        推薦度:
        導讀解析JavaScript循環(huán)和作用域之間的關系(附代碼):我們在工作中經常會用到JavaScript,他與我們的工作有密切的關系。但是JavaScript有一個特點,也許會讓開發(fā)者頭痛, 是其循環(huán)和作用域相關的,那接下里就說說他們之間的關系。舉個例子:const operations = [] for (var i = 0; i < 5

        我們在工作中經常會用到JavaScript,他與我們的工作有密切的關系。但是JavaScript有一個特點,也許會讓開發(fā)者頭痛, 是其循環(huán)和作用域相關的,那接下里就說說他們之間的關系。

        舉個例子:

        const operations = []
        for (var i = 0; i < 5; i++) {
         operations.push(() => {
         console.log(i)
         })
        }
        for (const operation of operations) {
         operation()
        }

        它基本是循環(huán)了5次,將一個函數添加到operations數組里面。這個函數可打印出循環(huán)變量索引值i.
        運行這些函數后期望的結果應該是:
        0 1 2 3 4

        但實際發(fā)生的是這樣的:

        5 5 5 5 5

        為什么會有這種情況? 因為使用的是var.由于提升了var變量, 上面的代碼等同于

        var i;
        const operations = []
        for (i = 0; i < 5; i++) {
         operations.push(() => {
         console.log(i)
         })
        }
        for (const operation of operations) {
         operation()
        }

        因此,在for-of循環(huán)中, i 依然是可見的, 它等于5,并且每次在函數中涉及到i ,都將使用這個值。
        那么我們應該如何做讓其變成我們想的這樣呢?
        最簡單的方案是用 let 聲明. 在ES2015中介紹到, 它們有很大的幫助,能避免關于使用var聲明的一些奇怪問題。
        簡單的在循環(huán)變量時將var 變成 let ,能夠很好的運行:

        const operations = []
        for (let i = 0; i < 5; i++) {
         operations.push(() => {
         console.log(i)
         })
        }
        for (const operation of operations) {
         operation()
        }

        這是輸出結果:

        0 1 2 3 4

        這是怎么實現的呢?這是因為每次循環(huán)重復的時候,都將重新創(chuàng)造 i ,同時每個函數添加operations數組時,能獲取它本身的i。
        記住你不能使用 const在這種情況下, 因為這會導致for在第二次循環(huán)時, 嘗試賦新值報錯。
        另外一個非常普遍的解決這個問題是使用pre-ES6代碼, 同時它被稱作即時調用函數表達式 (IIFE).
        在這種情況下,你可以包裝整個函數,并將i 綁定在它上面。自這種方式,你正在創(chuàng)造一個能立即執(zhí)行的函數,你從其返回的一個新的函數。因此我們可以稍后執(zhí)行它。

        const operations = []
        for (var i = 0; i < 5; i++) {
         operations.push(((j) => {
         return () => console.log(j)
         })(i))
        }
        for (const operation of operations) {
         operation()
        }

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        解析JavaScript循環(huán)和作用域之間的關系(附代碼)

        解析JavaScript循環(huán)和作用域之間的關系(附代碼):我們在工作中經常會用到JavaScript,他與我們的工作有密切的關系。但是JavaScript有一個特點,也許會讓開發(fā)者頭痛, 是其循環(huán)和作用域相關的,那接下里就說說他們之間的關系。舉個例子:const operations = [] for (var i = 0; i < 5
        推薦度:
        標簽: js 代碼 循環(huán)
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 9420免费高清在线视频| 日本一道本高清免费| 亚洲国产主播精品极品网红| 中国亚洲呦女专区| 午夜宅男在线永久免费观看网| 亚洲最大视频网站| 久久精品网站免费观看| 日韩亚洲国产高清免费视频| 国内大片在线免费看| 国产精品亚洲一区二区三区 | 亚洲精品网站在线观看你懂的| 可以免费观看的国产视频| 亚洲AV无码一区二区三区系列| 久久久久成人精品免费播放动漫| 亚洲天天做日日做天天看| 99久久99久久精品免费看蜜桃| 亚洲人妖女同在线播放| 在线免费观看一级毛片| 特级无码毛片免费视频| 亚洲精品成人无限看| 永久免费视频网站在线观看| 亚洲一线产区二线产区区| 免费一级成人毛片| 青青操免费在线视频| 亚洲不卡视频在线观看| 国产又粗又长又硬免费视频| 中国性猛交xxxxx免费看| 亚洲视频欧洲视频| 国产午夜免费秋霞影院| 久久免费高清视频| 亚洲AV日韩综合一区尤物| 国产成人精品日本亚洲专区 | 国产成人精品日本亚洲| 91成人免费在线视频| 国产精品亚洲а∨无码播放麻豆 | 91亚洲自偷在线观看国产馆| 精品国产免费观看一区| 中文字幕无码免费久久| 亚洲日韩精品国产3区| 亚洲精品中文字幕乱码三区| 拍拍拍又黄又爽无挡视频免费|