错误发生在if(serversInfo[user.guild.id].modlog_enabled

另外,如果有帮助,请输入let serversInfo = JSON.parse(fs.readFileSync('./data/servers.json', 'utf8'));

client.on('guildBanAdd', user => {
  if (serversInfo[user.guild.id].modlog_enabled == true && serversInfo[user.guild.id].modlog_channel !== null) {
    var d = Date.now()
    d = new Date(d)
    d = d.getMonth() + 1 + '/' + d.getDate() + '/' +
      d.getFullYear() + ' ' +
      (d.getHours() > 12 ? d.getHours() - 12 : d.getHours()) + ':' + d.getMinutes() + ' ' + (d.getHours() >= 12 ? 'PM' : 'AM')

    client.channels
      .get(serversInfo[user.guild.id].modlog_channel)
      .send(`${user}**//**${user.id} was banned on **${d}**.`)

  } else if (err) {
    console.log(err)
  }
})


我尝试仅使用guild.id,但是似乎没有用,因为我会收到guild is not defined的错误。 modlog_enabled已在.json文件中设置为true,但没有看到它。检查modlog_enabled时,我的其他事件运行正常。

最佳答案

client.on('guildBanAdd')返回公会和用户,但不能同时返回。
而且用户不再在行会上了,因此使用user.guild毫无意义。

client.on('guildBanAdd', (guild, user) => {

    if(serversInfo[guild.id].modlog_enabled == true && serversInfo[guild.id].modlog_channel !== null){
        var d = Date.now();
        d = new Date(d);
        d = (d.getMonth()+1)+'/'+d.getDate()+'/'+d.getFullYear()+' '+(d.getHours() > 12 ? d.getHours() - 12 : d.getHours())+':'+d.getMinutes()+' '+(d.getHours() >= 12 ? "PM" : "AM");

        client.channels.get(serversInfo[guild.id].modlog_channel).send(`${user}**//**${user.id} was banned on **${d}**.`)
    } else if (err){console.log(err)}

});

关于javascript - Discord.js TypeError:无法读取未定义的属性“id”,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/50101090/

10-09 22:27