Discord.JS foreach 中的 addField 不工作

Discord.JS addField in foreach not working

由于某种原因,addField 无法正常工作。没有错误,只是没有显示出来。

query 和 foreach 都很好并且可以工作。我在命令中使用了那个确切的设置。它只是不适用于嵌入。

const con = mysql.createConnection({
host: "localhost",
user: "root",
password: "",
database: "testbot"
});
con.connect(err => {
if(err) throw err;
console.log("Connected to database!");
});


function statusUpdate() {

var update = bot.channels.get('5777623821454355545');
const statusEmbed = new Discord.RichEmbed();
statusEmbed.setTitle("**Current Statuss:**");
con.query("SELECT * FROM games", function(err, result, fields) {
   if(err) throw err;
    Object.keys(result).forEach(function(key) {
        var row = result[key];
        statusEmbed.addField('**' + row.name + '**' + ' - ' + '(' + row.description + ')' + ' - ' + '**' + row.status + '**');
    });
});
update.send(statusEmbed);
}

bot.on('ready', () => {
console.log('This bot is online!');
statusUpdate();
});

您必须在查询回调中更新 statusEmbed,因为如果不这样做,您将在 addField 尚未执行时更新它。

callback 表示查询是异步的。


基于回调的解决方案

function statusUpdate(callback) {
  const update = bot.channels.get('577762382164525066');

  const statusEmbed = new Discord.RichEmbed();

  statusEmbed.setTitle('**Current Statuss:**');

  con.query('SELECT * FROM games', function(err, result, fields) {
    if (err) {
      callback(err);

      return;
    }

    Object.keys(result).forEach((key) => {
      const row = result[key];

      statusEmbed.addField(`**${row.name}** - (${row.description}) - **${row.status}**`);
    });

    update.send(statusEmbed);

    callback(false);
  });
}

备选

function statusUpdate() {
  const update = bot.channels.get('577762382164525066');

  const statusEmbed = new Discord.RichEmbed();

  statusEmbed.setTitle('**Current Statuss:**');

  con.query('SELECT * FROM games', function(err, result, fields) {
    if (err) {
      throw err;
    }

    Object.keys(result).forEach((key) => {
      const row = result[key];

      statusEmbed.addField(`**${row.name}** - (${row.description}) - **${row.status}**`);
    });

    update.send(statusEmbed);
  });
}