Проблемы с рендерингом компонента - PullRequest
0 голосов
/ 14 марта 2019

Игнорировать испанский в коде xD. У меня проблемы с рендерингом компонента (остальная часть таблицы). Когда я делаю console.log(clientes) данные из массива есть, но в этой части что-то происходит

return(
        <React.Fragment>
            {Object.keys(clientes).map(cliente => (
                <Cliente
                    key={cliente}
                    info={this.props.clientes[cliente]} 
                />
            ))}
        </React.Fragment>
    )

Вот весь код:

import React,{Component} from 'react';
import Cliente from './Cliente';

export default class ListadoClientes extends Component {

    mostrarClientes = () => {
        const clientes = this.props.clientes;

        if(clientes.length === 0) return null;

        return(
            <React.Fragment>
                {Object.keys(clientes).map(cliente => (
                    <Cliente
                        key={cliente}
                        info={this.props.clientes[cliente]} 
                    />
                ))}
            </React.Fragment>
        )
    }

    render() {
        return (
            <div className="container col-12">
                <table className="table table-striped table-bordered">
                    <thead className="text-center">
                        <tr>
                            <th scope="col" className="align-middle">RAZÓN SOCIAL</th>
                            <th scope="col" className="align-middle">RUC</th>
                            <th scope="col" className="align-middle">CORREO ELECTRÓNICO</th>
                            <th scope="col" className="align-middle">TELÉFONO</th>
                            <th scope="col" className="align-middle">DIRECCIÓN</th>
                            <th scope="col" className="align-middle" colSpan="2">ACCIÓN</th>
                        </tr>
                    </thead>
                    <tbody>
                        {this.mostrarClientes()} 
                    </tbody>
                </table>
            </div>
        );
    }
}

Все, что я получаю, это: enter image description here

Это вывод console.log(clientes)

enter image description here

Это код Cliente

import React,{Component} from 'react';

export default class Cliente extends Component {

render() {

    const {RAZON_SOCIAL, RUC, DIRECCION, TELEFONO, EMAIL, ID_CLIENTE} = this.props.info;

    return (
        <tr key={ID_CLIENTE} className="align-middle">
            <td>{RAZON_SOCIAL}</td>
            <td>{RUC}</td>
            <td>{EMAIL}</td>
            <td>{TELEFONO}</td>
            <td>{DIRECCION}</td>
            <td><button value={ID_CLIENTE} className="btn btn-warning">EDITAR</button></td>
            <td><button onClick={this.deleteEmpresa} value={ID_CLIENTE} className="btn btn-danger">ELIMINAR</button></td>             
        </tr>
    );
}

}

И вот где я получил все данные (я использую API в локальной сети) и отправил их другим компонентам:

import React,{Component} from 'react';
import {BrowserRouter, Route, Switch} from 'react-router-dom';
import axios from 'axios';

//COMPONENTES--------------------------
import Header from './Header';
import Clientes from './Clientes';
import Navegacion from './Navegacion';
//-------------------------------------

//API http://192.168.1.146:4181/

export default class Router extends Component {

state = {
    clientes: []
}

componentDidMount() {
    this.obtenerClientes();
}

//METODOS HTTP
obtenerClientes = () => {
    axios.get(`http://192.168.1.146:4181/`)
        .then(res => {
            this.setState({
                clientes: res.data
            })
        })
}

render() {
    return (
        <BrowserRouter>
            <div className="container-fluid">
                <div className="row justify-content-center">
                    <Header/>
                    <Navegacion/>
                    <Switch>
                        <Route exact path="/" render={() => {
                            return(
                                <Clientes
                                    clientes={this.state.clientes}
                                />
                            )
                        }}/>

                    </Switch>
                </div>
            </div>
        </BrowserRouter>
    );
}

}

Ответы [ 2 ]

0 голосов
/ 18 марта 2019

Вы должны изменить свой код, как показано ниже:

return(
        <React.Fragment>
            {Object.keys(clientes.data).map(cliente => (   // ==> Modify "clientes" to "clientes.data"
                <Cliente
                    key={cliente}
                    info={this.props.clientes.data[cliente]}   // ==> Modify "clientes" to "clientes.data"
                />
            ))}
        </React.Fragment>
    )
0 голосов
/ 15 марта 2019

Похоже, что ваши "клиенты", которые передаются через реквизиты, являются объектами этого типа {data: Array<Cliente>}.Используйте this.props.clientes.data.map(cliente=> ...

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