@Sanchik97

Почему выскакивает ошибка TypeError: scriptData is undefined?

Здравствуйте! Изучаю React и не могу понять, почему выскакивает вот такая ошибка: TypeError: scriptData is undefined; can't access its "map" property. Вот сам код

spoiler
import React, {Component} from "react";

export default class Scripts extends Component {
  render() {
    console.log(this.props);
    let { scriptData } = this.props;

    const scriptTemplate = scriptData.map(item => {
      return (
        <tr key={item.id}>
          <th scope="row">{item.id}</th>
          <td>{item.name}</td>
        </tr>
      );
    });

    return (
      <div className="container">
        <h1 className="m-5">Скрипты</h1>

        <table className="table table-hover">
          <thead>
            <tr>
              <th scope="col">#</th>
              <th scope="col">Название</th>
              <th scope="col">Действия</th>
            </tr>
          </thead>
          <tbody>{scriptTemplate}</tbody>
        </table>
      </div>
    );
  }
}
spoiler
import React, { Component } from "react";
import "./App.css";
import Navbar from "./component/Navbar/Navbar";
import Scripts from "./component/Scripts/Scripts"

const scriptArray = [
  {
    id: 1,
    name: `Первый скрипт`
  },
  {
    id: 2,
    name: `Второй скрипт`
  },
  {
    id: 3,
    name: `Третий скрипт`
  },
  {
    id: 4,
    name: `Четвертый скрипт`
  }
];



class App extends Component {
  render() {
    return (
      <React.Fragment>
        <Navbar />
        <Scripts scriptData={scriptArray} />
      </React.Fragment>
    );
  }
}

export default App;


Дальше компонент App рендерится в index.js
  • Вопрос задан
  • 82 просмотра
Решения вопроса 1
rockon404
@rockon404 Куратор тега React
Frontend Developer
С кодом все нормально. Либо ошибка в другом месте, либо вы выполняете сборку другой версии кода.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы