javascript - 回調(diào)函數(shù)如何訪問當(dāng)前函數(shù)作用下的值
問題描述
我在函數(shù)中定義了一個(gè)數(shù)組變量,里面存有6個(gè)元素,然后在該函數(shù)中調(diào)用回調(diào)函數(shù),在回調(diào)函數(shù)中無法訪問數(shù)組變量的值,但是可以訪問length屬性。感覺很迷惑,不知道該怎么解決。
for(var i=0;i<bookARR.length;i++){//在該書中寫入 有借圖書館id//因?yàn)閳D書館表需要所有書籍的_id,所以檢測有時(shí),記錄idconsole.log('在外面'+bookARR[i]);//9787539989891 9787533946777 9787569914078 9787513316286 9787218113180 9787535491978 Book.getBookByISBN(bookARR[i],function(err,book){ if(!book||err){console.log('huidiao'+bookARR.length);//6console.log('在里面'+bookARR[i]);//undefined undefined undefined undefined undefined undefinednewBook.push(bookARR[i]); }else{newBook_id.push(book._id); } ep.emit(’examine’);}) }
Book.getBookByISBN()是我在其他模塊定義的函數(shù)
問題解答
回答1:因?yàn)?p>for (var i = 0; i<10; i++) { setTimeout(function(){console.log(i)});}for (var i = 0; i<10; i++) { (function(i){ setTimeout(function(){console.log(i)}); })(i)}所以for(var i=0;i<bookARR.length;i++){ (function(i) {Book.getBookByISBN(bookARR[i],function(err,book){ if(!book||err){console.log('huidiao'+bookARR.length)console.log('在里面'+bookARR[i]);newBook.push(bookARR[i]); }else{newBook_id.push(book._id); } ep.emit(’examine’);}) })(i);}回答2:
在callback 中帶上 bookARR[i]
回答3:前面已經(jīng)說了原因了,其實(shí)就是在你定義Book.getBookByISBN()這個(gè)函數(shù)里面的回調(diào)調(diào)用的地方傳入bookArr[i]就好了,理解一下形參和實(shí)參
回答4:這是個(gè)典型的異步問題,i的作用域還在其中。因?yàn)楫惒降饶?getBookByISBN 方法調(diào)用callback的時(shí)候 i=bookARR.length。這已經(jīng)越界了,所以是undefined.
解決方:1.閉包2.let
相關(guān)文章:
1. python - django 里自定義的 login 方法,如何使用 login_required()2. python如何不改動(dòng)文件的情況下修改文件的 修改日期3. angular.js - Angular路由和express路由的組合使用問題4. angular.js - angularjs 用ng-reapt渲染的dom 怎么獲取上面的屬性5. mysql優(yōu)化 - mysql count(id)查詢速度如何優(yōu)化?6. 主從備份 - 跪求mysql 高可用主從方案7. css3 - [CSS] 動(dòng)畫效果 3D翻轉(zhuǎn)bug8. angular.js - 不適用其他構(gòu)建工具,怎么搭建angular1項(xiàng)目9. mysql主從 - 請(qǐng)教下mysql 主動(dòng)-被動(dòng)模式的雙主配置 和 主從配置在應(yīng)用上有什么區(qū)別?10. node.js - node_moduls太多了
![css3 - [CSS] 動(dòng)畫效果 3D翻轉(zhuǎn)bug](http://www.cgvv.com.cn/attached/image/news/202304/110831f073.png)