【问题标题】:Json cannot read property of undefinedJson 无法读取未定义的属性
【发布时间】:2019-11-13 00:08:32
【问题描述】:

当我在我的 discord 机器人中执行命令(键入正常消息时不会发生错误)时,我收到一条错误消息:

无法读取未定义的“活动”属性

当我尝试从存储用户数据的 json 文件中对对象进行控制台日志记录时,就会发生这种情况。

这些是我的机器人的 index.js 文件的第一行代码,我尝试控制台日志的行是发生错误的地方

const Discord = require('discord.js');
const client = new Discord.Client();
const fs = require("fs");
const prefix = '>';

let xp = require("./storage/dbGeneral.json");
let pr = require("./storage/dbPremium.json");
let lv = require("./storage/levels.json");

client.on('message', message => {
    console.log(pr[message.author.id].active);
}

这是我存储数据的json文件

{
  "397387465024864257": {
    "active": false,
    "dateStart": "",
    "dateEnd": ""
  }
}

这是错误:

index.js:14
    console.log(pr[message.author.id].active);
                                      ^

TypeError: Cannot read property 'active' of undefined
    at Client.client.on.message (index.js:14:39)
    at emitOne (events.js:116:13)
    at Client.emit (events.js:211:7)
    at MessageCreateHandler.handle (\node_modules\discord.js\src\client\websocket\packets\handlers\MessageCreate.js:9:34)
    at WebSocketPacketManager.handle (\node_modules\discord.js\src\client\websocket\packets\WebSocketPacketManager.js:103:65)
    at WebSocketConnection.onPacket (\node_modules\discord.js\src\client\websocket\WebSocketConnection.js:333:35)
    at WebSocketConnection.onMessage (\node_modules\discord.js\src\client\websocket\WebSocketConnection.js:296:17)
    at WebSocket.onMessage (\node_modules\ws\lib\event-target.js:120:16)
    at emitOne (events.js:116:13)
    at WebSocket.emit (events.js:211:7)

我真的不知道错误的原因是什么,所有其他 json 请求都可以使用相同的方法正常工作。

【问题讨论】:

标签: node.js discord.js


【解决方案1】:

该错误是由于尝试访问未定义的属性引起的。 要解决您的问题,您必须检查用户是否存在于您的数据库中。

let user = pr[message.author.id];
if(user) console.log(user.active)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2023-04-01
    • 2020-12-28
    • 2015-10-06
    • 2023-03-20
    • 1970-01-01
    • 1970-01-01
    • 2023-03-23
    • 1970-01-01
    相关资源
    最近更新 更多