關于解決JS遍歷多個異步回調(diào)完美引用外部變量的幾個辦法

最近項目里用到了多選圖片二維碼識別上傳,由于二維碼識別是異步回調(diào),再次列舉一下如何在循環(huán)回調(diào)引用變量

描述

由于JS里for循環(huán)是同步任務,而reader.onloadend是異步任務,所以同步的會先執(zhí)行完循環(huán)結(jié)束,等到異步回調(diào)引用外部變量所以,始終是循環(huán)最后一次值,so,歸納了下面三種方式

Promise

Promise.all函數(shù)可以并行調(diào)用參數(shù)中的Promise對象方法历等,并且將所有Promise對象方法返回值作為數(shù)組輸入到then回調(diào)中

fileReaderPromise = (file) =>{
   let promise = new Promise((resolve, reject) =>{
            let reader = new FileReader()
            reader.readAsDataURL(file)
            reader.onloadend = (e) => {
                let new_result = e.target.result
                resolve(new_result)
            }
   });
   return promise;
}

handle_images = (files) => {
    let filesPromise = files.map(file => this.fileReaderPromise(file))
    Promise.all(filesPromise)
        .then(data => {
            data.map((image,index) => console.log('image',image,'index',index))
        })
}

自執(zhí)行函數(shù)

創(chuàng)建自執(zhí)行函數(shù)局部作用域,保證外部變量不受影響

handle_images = (files) => {
    _.map(files, (file,index) => {
        (function(new_file,new_index){
            let reader = new FileReader()
            reader.readAsDataURL(file)
            reader.onloadend = (e) => {
                let new_result = e.target.result
                //...這里你可以引用new_file,new_index
                console.log('new_file',new_file,'new_index',new_index)
            }
         }.bind(this)(file,index)
    }
}

遞歸

handle_images = (i) => {
    let new_i = i
    if (new_i<files.length){
        let file = files[i]
        let reader = new FileReader()
        reader.readAsDataURL(file)
        reader.onloadend = (e) => {
            let new_result = e.target.result
            //...
            console.log('file',file,'i',i)
            
            //邏輯處理完后
            new_i++;
            this.handle_images(new_i)
        }
    }
}
//調(diào)用
this.handle_images(0)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市裙戏,隨后出現(xiàn)的幾起案子贞间,更是在濱河造成了極大的恐慌,老刑警劉巖继找,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喘帚,死亡現(xiàn)場離奇詭異,居然都是意外死亡恨狈,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門呛讲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來禾怠,“玉大人,你說我怎么就攤上這事贝搁÷鹗希” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵雷逆,是天一觀的道長弦讽。 經(jīng)常有香客問我,道長膀哲,這世上最難降的妖魔是什么往产? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮某宪,結(jié)果婚禮上仿村,老公的妹妹穿的比我還像新娘。我一直安慰自己缩抡,他們只是感情好奠宜,可當我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著瞻想,像睡著了一般压真。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蘑险,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天滴肿,我揣著相機與錄音,去河邊找鬼佃迄。 笑死泼差,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的呵俏。 我是一名探鬼主播堆缘,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼普碎!你這毒婦竟也來了吼肥?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎缀皱,沒想到半個月后斗这,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡啤斗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年表箭,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片钮莲。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡免钻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出臂痕,到底是詐尸還是另有隱情伯襟,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布握童,位于F島的核電站,受9級特大地震影響叛赚,放射性物質(zhì)發(fā)生泄漏澡绩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一俺附、第九天 我趴在偏房一處隱蔽的房頂上張望肥卡。 院中可真熱鬧,春花似錦事镣、人聲如沸步鉴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽氛琢。三九已至,卻和暖如春随闪,著一層夾襖步出監(jiān)牢的瞬間阳似,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工铐伴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留撮奏,地道東北人。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓当宴,卻偏偏與公主長得像畜吊,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子户矢,可洞房花燭夜當晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容