【发布时间】:2023-03-22 20:50:02
【问题描述】:
我的一个控制器中有一个方法。控制器的目的是使用 webshot package 打印一个 url 数组。
这是有问题的代码:
router.post('/capture', function (req, res, next) {
//Check params remove
var json = JSON.parse(req.body.data);
var promise = new Promise(function (resolve, reject) {
var totalImages = Object.keys(json).length;
var arrayListUrlImages = new Array(totalImages);
var counter = 0;
var completeDir = dir + ''; //Directory URL
for (var value of json) {
var url = 'http://example.com/' + id + '/' + value.anotherValue;
var folder = completeDir + id + '/' + value.anotherValue + '.jpg';
//Options for capturing image
var options = {
renderDelay: 1000,
quality: 100,
phantomConfig:
{
'local-to-remote-url-access': 'true',
'ignore-ssl-errors': 'true'
}
};
var anotherValue = value.anotherValue;
(function (anotherValue) {
webshot(url, folder, options, function (err) {
// screenshot now saved
if (err === null) {
var urlImage = "http://example.com/images/" + id + "/" + anotherValue + ".jpg";
arrayListUrlImages.push(urlImage);
counter++;
console.log("Counter: " + counter);
if (counter === totalImages) {
resolve(arrayListUrlImages);
}
}
else {
reject(err);
}
});
})(anotherValue);
}
}).then(function (arrayImages) {
res.send(arrayImages);
}).catch(function (errorVale) {
res.send(null);
});
});
这段代码运行没有问题……但我想做得更好。我不知道需要检查多少个 URL(这是重要的细节,因为我需要为每个或类似的 URL 做一个)。
我已经阅读了关于async package... 的更好的选择是将此代码移动到类似 async.parallel 的位置吗?我可以在代码中使用 yield 吗?
谢谢!
【问题讨论】:
-
不知道为什么这个问题被否决了……
标签: javascript node.js express yield