Задать вопрос
@aznhautroalvyl

Как преобразовать в JSON результат выборки и передать на клиентскую часть?

На серверной части (backend) с помощью Sequelize подключаюсь к базе данных Postgres и получаю выборку данных по одной из таблиц (сущностей). При попытке передать на клиентскую часть (frontend) результат выборки в формате JSON получаю ошибку в консоли браузера:

Uncaught (in promise) TypeError: this.state.party.map is not a function


В чём может быть проблема? Что не так я делаю?
Код backend-а:
const express = require('express');
const app = express();
const Sequelize = require('sequelize');

const sequelize = new Sequelize('testdb', 'postgres', 'somePassword', {
  dialect: 'postgres',
  define: {
    timestamps: false
  }
}); // данные для подключения к бд

sequelize
  .authenticate()
  .then(() => {
    console.log('Connection has been established successfully.');
  })
  .catch(err => {
    console.error('Unable to connect to the database: ', err);
  }); // подключение к бд

const Party = sequelize.define('party', {
  name: {
    type: Sequelize.STRING
  }
}); // определяем модель (таблицу в бд) Party

Party.findAll().then(party => {
  console.log(JSON.stringify(party));
}); // выборка данных (выводим в консоль для проверки)

app.route('/party-table')
  .get((req, res) => {
    res.send('get...');
  })
  .post((req, res) => {
    console.log(req.body);
   res.send(     
      Party.findAll().then(party => {
        return JSON.stringify(party);
      }) // выборка данных      
  );
  })
  .put((req, res) => {
    res.send('put');
  });

const PORT = process.env.PORT || 3000;

app.listen(PORT, () => {
  console.log(`Server listening on: ${PORT}`);
});


Код frontend-а:
import React, { PropTypes, Component } from 'react';

class PartyTable extends Component {
  constructor(props) {
    super(props);
    this.state = {
      party: []
    };
    this.handleFetch = this.handleFetch.bind(this);
  }

  componentDidMount() {
    this.handleFetch();
  }

  handleFetch() {
    fetch('http://127.0.0.1:3000/party-table', {
      method: 'POST'
    })
      .then((response) => {
        if (response.status >= 400) {
          throw new Error('Bad response from server');
        }
        return response.json();
      })
      .then(stories =>
        this.setState({ party: stories }) // новое состоняние
      );
  }

  render() {
    return (
      <table className='table table-striped table-hover table-bordered'>
        <thead className='table__thead'>
          <TableHeader/>
        </thead>
        <tbody>
        {this.state.party.map(item => {                              // на эту строку ругается браузер (сообщение об ошибке в консоли)
          return (<TableRow key={item.id} value={item.name}/>);
        })
        }
        </tbody>
      </table>
    );
  }
}

PartyTable.propTypes = propTypes;
PartyTable.defaultProps = defaultProps;
export default PartyTable;


Результат запроса в JSON-формате, который выводится в консоль на сервере:
[{"id":1,"name":"Партия1"},{"id":2,"name":"Партия2"},{"id":3,"name":"Партия3"},{"id":4,"name":"Партия4"},{"id":5,"name":"Партия5"}]


То, что приходит на клиента:
{"isFulfilled":false,"isRejected":false}
  • Вопрос задан
  • 729 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
rockon404
@rockon404 Куратор тега React
Frontend Developer
Проблемное меcто:
res.send(     
  Party.findAll().then(party => {
    return JSON.stringify(party);
  });
);

Исправленный вариант:
Party.findAll().then(party => res.json(party));

А еще лучше использовать async/await:
.post(async (req, res) => {
  const party = await Party.findAll();
  res.json(party);
})

или:
.post(async (req, res) => {
  res.json(await Party.findAll());
})
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

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