Node.js Async/Promise 用 JIMP 解释?
Node.js Async/Promise explanation with JIMP?
我正在开发一个 Discord 机器人,它可以获取上传的图片附件,在编辑后将其保存到一个临时文件,然后将其上传到 Discord 服务器。一切正常,除了时间。 sendImage
函数在 generateImagePixel
函数之后被调用,但在 jimp.write
完成之前尝试上传临时图像,导致 ENOENT 错误。我该如何解决我的计时问题?
client.on('message', message => {
if (message.content.includes(config.prefix + 'pixel')) {
var tempname = d.getTime();
console.log(tempname);
generateImagePixel(message.attachments, tempname).then(() => sendImage(tempname, message))
}
});
function generateImagePixel(msg, name) {
return new Promise((resolve, reject) => {
msg.forEach(a => {
try {
jimp.read(a.url, function (err, image) {
const clone = image.clone();
clone.pixelate(8)
.rgba(true)
.filterType(0)
.write('./temp/' + name + '.png');
});
} catch(err) {
console.log(err);
}
});
resolve(name)
})
}
function sendImage(tempname, msg) {
msg.channel.send({
file: './temp/'+ tempname + '.png' // Or replace with FileOptions object
});
}
这是一个在同步循环中执行异步函数的典型例子。
jimp.read
是异步的,所以每次调用 returns 都会在实际完成之前立即调用。因此 msg.forEach
也在 jimp
完成之前完成。
一旦你使用异步的东西,你所做的一切都必须是异步的:
function generateImagePixel(msg, name) {
const promises = msg.map(attachment => {
return jimp.read(attachment.url)
.then(image => {
return image
.pixelate(8)
.rgba(true)
.filterType(0)
.write('./temp/' + name + '.png');
})
.catch(console.error);
});
return Promise.all(promises)
.then(() => name);
}
我正在开发一个 Discord 机器人,它可以获取上传的图片附件,在编辑后将其保存到一个临时文件,然后将其上传到 Discord 服务器。一切正常,除了时间。 sendImage
函数在 generateImagePixel
函数之后被调用,但在 jimp.write
完成之前尝试上传临时图像,导致 ENOENT 错误。我该如何解决我的计时问题?
client.on('message', message => {
if (message.content.includes(config.prefix + 'pixel')) {
var tempname = d.getTime();
console.log(tempname);
generateImagePixel(message.attachments, tempname).then(() => sendImage(tempname, message))
}
});
function generateImagePixel(msg, name) {
return new Promise((resolve, reject) => {
msg.forEach(a => {
try {
jimp.read(a.url, function (err, image) {
const clone = image.clone();
clone.pixelate(8)
.rgba(true)
.filterType(0)
.write('./temp/' + name + '.png');
});
} catch(err) {
console.log(err);
}
});
resolve(name)
})
}
function sendImage(tempname, msg) {
msg.channel.send({
file: './temp/'+ tempname + '.png' // Or replace with FileOptions object
});
}
这是一个在同步循环中执行异步函数的典型例子。
jimp.read
是异步的,所以每次调用 returns 都会在实际完成之前立即调用。因此 msg.forEach
也在 jimp
完成之前完成。
一旦你使用异步的东西,你所做的一切都必须是异步的:
function generateImagePixel(msg, name) {
const promises = msg.map(attachment => {
return jimp.read(attachment.url)
.then(image => {
return image
.pixelate(8)
.rgba(true)
.filterType(0)
.write('./temp/' + name + '.png');
})
.catch(console.error);
});
return Promise.all(promises)
.then(() => name);
}