[英]How to wrap an asynchronous function to avoid code duplication?
我試圖通過將代碼包裝在單獨的函數中來避免代碼重復。 問題是d3.json是異步的,因此有時會返回一個空的info對象。 有沒有辦法避免代碼重復?
function getData(endpoint){
//long stuff
var info = {"succeeded": 1,"datum":[], "message":""};
d3.json(endpoint, function(error, data) {
//long stuff
info.datum = data;
return info;
});
return info;
}
一旦進入異步調用的世界,您將再也無法返回,因此,如果不使包裝函數也實現異步,就無法做到這一點。 這樣的事情可能會起作用:
function getData(endpoint, callback) {
d3.json(endpoint, function(error, data) {
var info = {
succeeded: 1,
data: data,
message: ""
};
callback(info);
});
};
您的回調函數將接受一個參數,該參數將成為您的“ info”對象。
請注意,我在d3回調函數中將信息對象的創建移到了更靠近它使用的位置,但這只是樣式首選項。 當然,您可以根據需要將其放回戶外。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.