将数据从 promise then 方法传递到对象方法
Passing data from promise then method to an object method
如何将 data
从 promise then
方法传递给对象方法。
this.httpReq(url).then(function (data) {
this.storeData(data);
});
我知道这里 I 超出了范围并且 this
没有引用我的对象。但是,尽管如此,我还是不明白如何解决它。
您可以在下面找到完整的代码片段。
最后,我想从服务API中获取数据,并存储在对象数组属性this.storage
中。
var http = require('http');
function CoubApi (url) {
this.url = url;
this.storage = [];
this.httpReq = httpReq;
this.searchData = searchData;
this.storeData = storeData;
}
function httpReq (url) {
var promise = new Promise (function (resolve, reject) {
http.get(url, function (res) {
var data = '';
res.on('data', function (chunk) {
data += chunk;
});
res.on('end', function () {
if(data.length > 0) {
resolve(JSON.parse(data));
} else {
reject("Error: HTTP request rejected!");
}
});
}).on('error', function (err) {
console.log("Error: ", e);
});
});
return promise;
}
function storeData (data) {
var i;
console.log("Storrrreee");
for(i = 0; i < 10; i++) {
this.storage.push(data.coubs[i]);
}
}
function searchData (searchtext, order, page) {
var url = this.url+
"search?q="+searchtext+
"&order_by="+order+
"&page="+page;
this.httpReq(url).then(function (data) {
this.storeData(data);
});
}
var coub = new CoubApi("http://coub.com/api/v2/");
coub.searchData("cat", "newest_popular", 1);
console.log(coub.storage);
您可以将其存储在变量中:
var self = this;
this.httpReq(url).then(function (data) {
self.storeData(data);
});
或使用绑定:
this.httpReq(url).then(function (data) {
this.storeData(data);
}.bind(this));
如何将 data
从 promise then
方法传递给对象方法。
this.httpReq(url).then(function (data) {
this.storeData(data);
});
我知道这里 I 超出了范围并且 this
没有引用我的对象。但是,尽管如此,我还是不明白如何解决它。
您可以在下面找到完整的代码片段。
最后,我想从服务API中获取数据,并存储在对象数组属性this.storage
中。
var http = require('http');
function CoubApi (url) {
this.url = url;
this.storage = [];
this.httpReq = httpReq;
this.searchData = searchData;
this.storeData = storeData;
}
function httpReq (url) {
var promise = new Promise (function (resolve, reject) {
http.get(url, function (res) {
var data = '';
res.on('data', function (chunk) {
data += chunk;
});
res.on('end', function () {
if(data.length > 0) {
resolve(JSON.parse(data));
} else {
reject("Error: HTTP request rejected!");
}
});
}).on('error', function (err) {
console.log("Error: ", e);
});
});
return promise;
}
function storeData (data) {
var i;
console.log("Storrrreee");
for(i = 0; i < 10; i++) {
this.storage.push(data.coubs[i]);
}
}
function searchData (searchtext, order, page) {
var url = this.url+
"search?q="+searchtext+
"&order_by="+order+
"&page="+page;
this.httpReq(url).then(function (data) {
this.storeData(data);
});
}
var coub = new CoubApi("http://coub.com/api/v2/");
coub.searchData("cat", "newest_popular", 1);
console.log(coub.storage);
您可以将其存储在变量中:
var self = this;
this.httpReq(url).then(function (data) {
self.storeData(data);
});
或使用绑定:
this.httpReq(url).then(function (data) {
this.storeData(data);
}.bind(this));