Невозможно создать ключ свойства для строки React - PullRequest
2 голосов
/ 19 марта 2019

Я создаю чат-приложение с использованием React и получаю сообщение об ошибке с кодом:

TypeError: Невозможно создать свойство 'key' для строки 'room1'

Я использую firebase в качестве базы данных и имею два объекта. Я использую room1 и room2, и я получил ошибку при прохождении двух объектов.

Я занимаюсь этим уже несколько дней и не могу этого понять. Вот мой код:

import React, { Component } from 'react';

class RoomList extends Component {
    constructor(props) {
      super(props);
         this.state = {
     rooms: [],
            newRoomName: ''
         };
         this.roomsRef = this.props.firebase.database().ref("rooms");
    }

    componentDidMount() {
      this.roomsRef.on('child_added', snapshot => {
         const room = snapshot.val();
         room.key = snapshot.key;
         this.setState({ rooms: this.state.rooms.concat( room ) })
      });
    }

    createRoom(newRoomName) {
        this.roomsRef.push({
            name: newRoomName 
        });
        this.setState({ newRoomName: '' });
    }

    handleChange(e) {
        this.setState({ newRoomName: e.target.value });
    }

    handleSubmit(e) {
        e.preventDefault();
        this.createRoom(this.state.newRoomName);
    }

    render() {
      return (
          <section className="room-list">
        <h3>Rooms</h3>
                {this.state.rooms.map( room => 
                     <li key={room.key} >
                        {room.name}
                     </li>
                )}
                <form id="create-room" onSubmit={ (e) => this.handleSubmit(e) }>
                    <input type="text" value={ this.state.newRoomName } onChange={ (e) => this.handleChange(e) }/>
                    <input type="submit" />
                </form>
          </section>
      );
    }
}

export default RoomList;

Ошибка ловится, где room.key = snapshot.key

и вот мой файл App.js

import React, { Component } from 'react';
import './App.css';
import * as firebase from 'firebase';
import RoomList from './components/RoomList';

// Initialize Firebase
  var config = {
    apiKey: "AIzaSyD4geqW7VZ7e7trfIASUQaWaJA9pmGDzUE",
    authDomain: "bloc-chat-81cb7.firebaseapp.com",
    databaseURL: "https://bloc-chat-81cb7.firebaseio.com",
    projectId: "bloc-chat-81cb7",
    storageBucket: "bloc-chat-81cb7.appspot.com",
    messagingSenderId: "229890444186"
  };
  firebase.initializeApp(config);

class App extends Component {
  constructor(props) {
    super(props);
    this.state = {
      rooms: [],
      newRoomName: ''
    };
  }

  render() {
    return (
      <div className="App">
        <h1 className="App-title">Bloc Chat</h1>
        <main>
           <RoomList firebase={firebase} />
        </main>
      </div>
    );
  }
}

export default App;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...