首页 > 解决方案 > 对象数组在控制台中显示为 [object Object] 而不是字符串

问题描述

我不明白为什么会发生这种情况我已经手动添加了示例数据,然后我稍后会推送更多数据。最终我想在一个平面列表中显示数据。请帮助我,这对我的项目非常重要。谢谢你代码:

class TasksScreen extends Component {
constructor(props) {
  super(props);

  this.state = {
    tasks: [],
  };
  var tempTasks = [
    {
      key: 'abc',
      val: 'abc',
    },
  ];
  var that = this;

  var taskRef = database()
    .ref('/Tasks/' + auth().currentUser.uid)
    .on('value', dataSnapshot => {
      var key = dataSnapshot.key;
      console.log('UID KEY: ' + key);
      dataSnapshot.forEach(childSnaps => {
        var key = childSnaps.key;
        console.log('TASKID KEY: ' + key);
        childSnaps.forEach(taskData => {
          var taskKey = taskData.key;
          var taskVal = taskData.val();
          console.log('taskData KEY: ' + taskKey);
          console.log('taskData VAL: ' + taskVal);
          console.log('taskData.val().title: ' + taskVal);
          tempTasks.push({
            taskTitle: 'title',
            taskDescription: 'description',
            taskDueTime: 'time',
            taskDuedate: 'date',
          });
        });
      });
      console.log('tempTasks: ' + tempTasks);
      that.setState({tasks: tempTasks});
      console.log('STATE TASKS: ' + that.state.tasks);
    });
}

在此处输入图像描述

标签: javascriptfirebasereact-nativeobjectreact-native-flatlist

解决方案


由于您正在连接字符串,因此toString会调用对象的方法,该方法返回“[Object object]”。您可以用+昏迷替换 your,来单独评估您的每个变量console.log。:

let object = {
    title: 'test1',
    count: 10
}

// concatenation
console.log('object : ' + object);

// individual evaluation.
console.log('object : ', object);


推荐阅读