封装 node.js 请求的构造函数
Structuring functions that encapsulate node.js request
我正在函数内调用 API。此时我得到 "undefined" 作为返回值。我知道对 API 的调用是成功的,因为我试图在调用中获取的 URL 打印到术语没问题。我 99% 确定在请求函数完成之前触发了对封装函数的调用("undefined" 在列出 URL 之前返回)。想确认这一点并询问是否有教程或代码片段可以指出我在这种情况下应该遵循的模式的良好描述。 <-- 显然仍在与野兽的异步性质作斗争 :)
function GetPhotoURLs(url){
var photo_urls= new Array();
request({
url: url,
json: true
}, function (error, response, body) {
if (!error && response.statusCode === 200)
{
//console.log(body) // Print the json response
var inhale_jsonp=body;
var blog_stream= inhale_jsonp.substring(22,inhale_jsonp.length-2); //getting JSON out of the wrapper
blog_stream=JSON.parse(blog_stream);
for(var i=0;i<blog_stream.posts.length;i++)
{
photo_urls[i]=blog_stream['posts'][i]['photo-url-500'];
console.log(photo_urls[i]+"\n"); //checking that I am getting all the URLs
}
console.log("success!");
console.log(photo_urls[1]);
return photo_urls;
}
else
{
photo_urls[0]='none';
console.log("nope!");
console.log(photo_urls[0]);
return photo_urls;
}
});
}
输出序列-->
1.未定义
2. URL列表
3. 成功消息 + 来自 URL 数组的第二个元素
request()
函数是异步的。因此,它在您的原始功能完成后很久就结束了。因此,您不能 return 它的结果(当函数 returns 时,结果甚至还不知道)。相反,您必须在回调中处理结果或从该回调中调用函数并将结果传递给该函数。
对于此类工作的一般设计模式,您可以按照上面的建议在回调中处理结果,或者改用 promises 来帮助您管理请求的异步性质。在所有情况下,您都将在某种回调中处理结果。
您可以阅读 this answer 以了解有关处理异步响应的更多详细信息。该特定答案是为客户端 ajax 调用编写的,但处理异步响应的概念是相同的。
在您的特定情况下,您可能希望 getPhotoURLs()
接受一个回调函数,您可以调用该函数并返回结果:
function GetPhotoURLs(url, callback){
.....
request(..., function(error, response, body) {
...
// when you have all the results
callback(photo_urls);
})
}
GetPhotoURLs(baseurl, function(urls) {
// process urls here
// other code goes here after processing the urls
});
我正在函数内调用 API。此时我得到 "undefined" 作为返回值。我知道对 API 的调用是成功的,因为我试图在调用中获取的 URL 打印到术语没问题。我 99% 确定在请求函数完成之前触发了对封装函数的调用("undefined" 在列出 URL 之前返回)。想确认这一点并询问是否有教程或代码片段可以指出我在这种情况下应该遵循的模式的良好描述。 <-- 显然仍在与野兽的异步性质作斗争 :)
function GetPhotoURLs(url){
var photo_urls= new Array();
request({
url: url,
json: true
}, function (error, response, body) {
if (!error && response.statusCode === 200)
{
//console.log(body) // Print the json response
var inhale_jsonp=body;
var blog_stream= inhale_jsonp.substring(22,inhale_jsonp.length-2); //getting JSON out of the wrapper
blog_stream=JSON.parse(blog_stream);
for(var i=0;i<blog_stream.posts.length;i++)
{
photo_urls[i]=blog_stream['posts'][i]['photo-url-500'];
console.log(photo_urls[i]+"\n"); //checking that I am getting all the URLs
}
console.log("success!");
console.log(photo_urls[1]);
return photo_urls;
}
else
{
photo_urls[0]='none';
console.log("nope!");
console.log(photo_urls[0]);
return photo_urls;
}
});
}
输出序列--> 1.未定义 2. URL列表 3. 成功消息 + 来自 URL 数组的第二个元素
request()
函数是异步的。因此,它在您的原始功能完成后很久就结束了。因此,您不能 return 它的结果(当函数 returns 时,结果甚至还不知道)。相反,您必须在回调中处理结果或从该回调中调用函数并将结果传递给该函数。
对于此类工作的一般设计模式,您可以按照上面的建议在回调中处理结果,或者改用 promises 来帮助您管理请求的异步性质。在所有情况下,您都将在某种回调中处理结果。
您可以阅读 this answer 以了解有关处理异步响应的更多详细信息。该特定答案是为客户端 ajax 调用编写的,但处理异步响应的概念是相同的。
在您的特定情况下,您可能希望 getPhotoURLs()
接受一个回调函数,您可以调用该函数并返回结果:
function GetPhotoURLs(url, callback){
.....
request(..., function(error, response, body) {
...
// when you have all the results
callback(photo_urls);
})
}
GetPhotoURLs(baseurl, function(urls) {
// process urls here
// other code goes here after processing the urls
});