@aleshaykovlev
html, css, js, node, webpack, sass, react

Не найдены значения из json, как исправить?

Создал файл db.json, запустил сервер - json-server db.json
Получаю данные с помощью fetch:
import React from 'react';

import { Header, ToUsers, Activity } from './components';

function App() {
  const [activitys, setActivitys] = React.useState([]);

  React.useEffect(() => {
    fetch('http://localhost:3000/activitys')
      .then((data) => data.json())
      .then((json) => {
        setActivitys(json.activitys);
      });
  });

  return (
    <div className="app-wrapper">
      <Header items={['О комплексе', 'О компании', 'Новости', 'Медиа-банк', 'Контакты']} />
      <ToUsers />
      <Activity items={activitys} />
    </div>
  );
}

export default App;


В Activity получаю данные:
import React from 'react';

import '../styles/components/activity.sass';

import { ArrowBlackPng } from '../assets';
import { ActivityBlock } from '../components';

function Activity({ items }) {
  return (
    <div className="activity-wrapper">
      <div className="activity-wrapper__container">
        <div className="activity-wrapper__header">
          <div className="activity-wrapper-title">Текущие и будущие мероприятия</div>
          <a href="/more-activity" className="activity-wrapper-more">
            Все мероприятия
            <img src={ArrowBlackPng} alt="" />
          </a>
        </div>
        <div className="activity-wrapper__list-activitys">
            {items.map((obj) => (
                <ActivityBlock key={obj.id} {...obj} />
            ))}
        </div>
      </div>
    </div>
  );
}

export default Activity;


Ошибка - TypeError: Cannot read property 'map' of undefined
  • Вопрос задан
  • 126 просмотров
Решения вопроса 1
profesor08
@profesor08 Куратор тега JavaScript
Используй TypeScript и подобные вещи отсеются сами собой. В данный момент в items может попасть что угодно, и ошибка вылезет только во время выполнения.
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
@twoone
fetch, в отличии от рендера react, это асинхронная операция, поэтому к моменту первого рендера items имеют значение undefined, а следовательно и метода .map также не существует. Проще всего сделать items опциональным -
function Activity({ items = []}) {}
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы