Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 29.05.2019
Сообщений: 7

Проблемы с setState при считывании данных с сервера

06.07.2020, 22:02. Показов 1222. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, только начал изучать react, пытаюсь с базы загрузить информацию себе в приложение. Вроде бы делаю всё правильно,
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
class App extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            items: []
        };
    }
 
    componentDidMount() {
        fetch("https://www.thecocktaildb.com/api/json/v1/1/filter.php?c=Cocktail")
        .then(res => res.json())
        .then((arr) => {this.setState({items: arr.drinks});}    );
 
        console.log(this.state.items);
    }
 
    render() {
        //var itemos= this.state.items.map(item =>
        //<li key={items.idDrink}>{items.strDrink}</li>
        //);
 
        return <ul>helloworld</ul>;
    }
}
 
ReactDOM.render(
    <App/>,
    document.getElementById('reactapp')
);
Однако в консоли выводится пустой массив размера 0. Если же я вставлю console.log(arr) вместо this.setState({items:arr.drink}), то в консоль выведутся нужные данные
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.07.2020, 22:02
Ответы с готовыми решениями:

Кодировка данных при считывании из БД
Здравствуйте. Подскажите пожалуйста, я записываю строку в базу SQLite вот так mybase.ExecSQL('insert into NewTable (MYTEXT)...

Проблема при считывании данных из dataGridView
Я сравниваю некое поле нового объекта с данными в столбце datagridview если это поле совпадает с каким-то значением из столбца то мы его...

Ошибка при считывании строковых данных
Нужно просто считать русский текст из файла, выводит смайлики без пробелов. #include &quot;stdafx.h&quot; #include &quot;fstream&quot; ...

1
Эксперт JS
 Аватар для Iverycool
1586 / 796 / 362
Регистрация: 01.02.2019
Сообщений: 1,047
06.07.2020, 23:47
Лучший ответ Сообщение было отмечено Evster как решение

Решение

Evster,
В доках же сказано:
setState() does not always immediately update the component

Не по теме:

Google translate: setState () не всегда сразу обновляет компонент


В чём прелесть react, так то что он стимулирует писать чистый код, не основанный на переменных "здесь и сейчас". Так что либо вы должны писать console.log в обработчике, либо в componentDidUpdate.
Кстати с хуками всё ещё проще:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import React, {useState, useEffect} from 'react';
 
function App() {
  const [items, setItems] = useState([]);
  useEffect(() => {
    fetch("https://www.thecocktaildb.com/api/json/v1/1/filter.php?c=Cocktail")
        .then(res => res.json())
        .then((arr) => setItems(arr.drinks));
  }, []);
  useEffect(() => {
    if (items) console.log(items);
  }, items);
  return <ul>helloworld</ul>;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.07.2020, 23:47
Помогаю со студенческими работами здесь

Ошибка при считывании данных с файла
Среда разработки Visual Studio 2008. Тип проэкта - консольное приложение. Проблема в следующем. Для считывания данных с файла...

Exception при считывании данных с помощью ifstream
При компилировании кода выдаёт ошибку (см. скрин), крутил код по-разному, проверил все функции, нерабочей оказалась &quot;read_file&quot;,...

Проверка правильности данных при считывании из файла
Вопрос, есть ли что-то подобное cin.bad, но для считывания из файла? Программа заполняет массив из текстового файла. Собственно, в коде все...

При считывании данных из файла дописываются лишние симолы
Здравствуйте. Пишу класс для работы с файлами на базе winapi. Столкнулся с проблемой. Описываю свои действия. 1)Создаю файл 1.txt с...

Предупреждения Visual Studio при считывании данных из массива
Коллеги! Программа из курса Stepik. Условия: Написать программу для подсчёта различных символов, которые поступают на вход. Входные...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru