简体   繁体   English

Discord.js:如何发送消息并从中收集反应

[英]Discord.js: How to send a message and collect reactions from it

I want the discord.js bot to send a message when a command is executed, react on it and then catch all reactions from users to do certain stuff, like respond to them.我希望 discord.js bot 在执行命令时发送一条消息,对其做出反应,然后捕获用户的所有反应以执行某些操作,例如响应它们。 No time limit should be applied to reactions.不应对反应施加时间限制。 I should also mention that I'm using a command handler and the message is being sent from another file than index.js (in which the collect even should occur).我还应该提到我正在使用命令处理程序,并且消息是从 index.js 之外的另一个文件发送的(甚至应该在其中进行收集)。

I tried doing a collector but no matter how I do it, the collector variable is not defined or not working.我尝试做一个收集器,但无论我怎么做,收集器变量都没有定义或不起作用。 I know it should be a collector for a fact though.我知道它应该是一个事实的收藏家。

Making a filter for the checkmark emoji:为复选标记表情符号制作过滤器:

  return reaction.emoji.name === `✅` && user.id === call.message.author.id;
}

Trying to catch reactions outside the command block itself (because if I do it IN the block the event won't work:试图捕捉命令块本身之外的反应(因为如果我在块中这样做,事件将不起作用:

collector.on(`collect`, (reaction, reactionCollector) => {
    console.log(`Caught ${reaction.emoji.name}`);
});

The errors I get are pretty much expected but I want to solve that:我得到的错误几乎是预料之中的,但我想解决这个问题:

collector.on(`collect`, (reaction, reactionCollector) => {
^

ReferenceError: collector is not defined

Maybe a global variable or setting the message id and then fetching?也许是一个全局变量或设置消息 ID 然后获取? Help me.帮我。

Why not include the Collector in your command.js?为什么不在 command.js 中包含收集器?

 const time = 60000 //amount of time to collect for in milliseconds

 receivedMessage.channel.send("Hello World")
 .then(async function (message) {
      await message.react('✅')
      const filter = (reaction, user) => {
           return //YOUR FILTER HERE;
      };

      const collector = message.createReactionCollector(filter, { time: time });

      collector.on('collect', (reaction, reactionCollector) => {
           //do stuff
      });
 });

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM