javascript - JS如何把回調閉包形參傳遞給外部環境的變量
問題描述
如題,請問如何把閉包里面的形參數據傳遞給外部變量
var outer;var map = new BMap.Map('allmap');var point = new BMap.Point(116.331398,39.897445);var gc = new BMap.Geocoder();gc.getLocation(point, function(rs){ var addComp = rs.addressComponents; //how to store this string to variable outer; //outer = addComp.province + ', ' + addComp.city + ', ' + addComp.district + ', ' + addComp.street + ', ' + addComp.streetNumber);});
使用賦值只能保證在閉包內數據有效,退出后就無效,使用new分配內存也無果,時間倉促來不及學習JS所以厚著臉皮來segmentfault問一下>3<
問題解答
回答1:用ajax async:false但是問題依舊? 你把代碼貼出來看看,按照常理來說應該是可以的。其它的方法1:可以在promise的then邏輯中處理異步值以及和異步值有關的邏輯。2:用generator配合yield同步化書寫的方式處理你的邏輯3:直接用async函數也可以。
回答2:你的代碼賦值方式是正確的,所謂【退出后就無效】可能是這樣的控制流問題:
var x = 0setTimeout(() => { // 這里 x 是 1 x = 1}, 1000)// 這里 x 還是 0console.log(x)
你的代碼中 gc.getLocation 如果和上面的示例一樣,是一個異步調用,那么就不能按照代碼書寫順序來保證代碼執行順序了。因此如果直接在后續的代碼中訪問 outer 變量,很可能拿到的就是異步調用完成前的舊值。
回答3:你可以現在外面定義個外部變量,比如Object類型,然后將其當做參數傳進去,通過在內部對Object賦值,實現傳值到外面
相關文章:
1. 查詢mysql數據庫中指定表指定日期的數據?有詳細2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
