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

Как подключить react-window?

Добавил react-window (npm install --save react-window)
Подскажите как правильно подключить react-window в моём компоненте
Сейчас он ругается:
5e6a8d76939cc434374591.png


Файл где я подключаю react-window:
import React, { Component } from "react";
import Grid from "@material-ui/core/Grid";
import Box from "@material-ui/core/Box";
import "./table.css";
import { connect } from "react-redux";
import actions from "../../actions";
import PropTypes from "prop-types";
import sort from "./sort";
import { FixedSizeList } from 'react-window';

function TitleColumn(data) {
  return (
    <Grid item xs={1}>
      <Box className="title_elem">
        <h3
          className="table_title-text"
          onClick={sort.bind(null, `${data.title.toLowerCase()}`, data.props)}
        >
          {data.title}
        </h3>
        {data.props.fourthData.data === `${data.title.toLowerCase()}` ? (
          <p>{data.props.fifthData.data}</p>
        ) : null}
      </Box>
    </Grid>
  );
}

class Table extends Component {
  render() {
    const data = this.props.info;
    return (
        <Grid
          container
          className="developer_block-time_feature time_feature_block"
        >
          <Grid container className="table_title">
            <TitleColumn props={this.props} title="Name" />
            <TitleColumn props={this.props} title="Job" />
            <TitleColumn props={this.props} title="City" />
            <TitleColumn props={this.props} title="Country" />
            <TitleColumn props={this.props} title="Latitude" />
            <TitleColumn props={this.props} title="Longitude" />
            <TitleColumn props={this.props} title="Date" />
          </Grid>

          <FixedSizeList                 <------------------------------вот ТАК Я ВСТАВИЛ И НЕ РАБОТАЕТ
            className="List"
            height={250}
            itemCount={311}
            itemSize={35}
            width={300}
          >
            {data.map((elem, index) => (
              <Grid container key={elem.id} className="table_row">
                <Grid item xs={1}>
                  <Box className="table_elem name_elem">{elem.name}</Box>
                </Grid>
                <Grid item xs={1}>
                  <Box className="table_elem job_elem">{elem.job}</Box>
                </Grid>
                <Grid item xs={1}>
                  <Box className="table_elem city_elem">{elem.city}</Box>
                </Grid>
                <Grid item xs={1}>
                  <Box className="table_elem country_elem">{elem.country}</Box>
                </Grid>
                <Grid item xs={1}>
                  <Box className="table_elem latitude_elem">{elem.latitude}</Box>
                </Grid>
                <Grid item xs={1}>
                  <Box className="table_elem longitude_elem">{elem.longitude}</Box>
                </Grid>
                <Grid item xs={1}>
                  <Box className="table_elem date_elem">
                    {`${elem.date.toLocaleString("en", {
                  year: "numeric",
                  month: "long",
                  day: "numeric"
                })}`}
                  </Box>
                </Grid>
              </Grid>
            ))}
          </FixedSizeList>     <------------------------------------вот ТАК Я ВСТАВИЛ И НЕ РАБОТАЕТ
        </Grid>
    );
  }
}

Table.propTypes = {
  fourthData: PropTypes.object.isRequired,
  fifthData: PropTypes.object.isRequired
};

const mapStateToProps = store => {
  return {
    firstData: store.firstData,
    secondData: store.secondData,
    thirdData: store.thirdData,
    fourthData: store.fourthData,
    fifthData: store.fifthData
  };
};

const mapDispatchToProps = dispatch => {
  return {
    setData: data => dispatch(actions.setData(data)),
    changeSearchData: searchData =>
      dispatch(actions.changeSearchData(searchData)),
    changeSort: sort => dispatch(actions.changeSort(sort)),
    setSortTitle: sortField => dispatch(actions.setSortTitle(sortField)),
    changeArrow: arrow => dispatch(actions.changeArrow(arrow))
  };
};

export default connect(mapStateToProps, mapDispatchToProps)(Table);
  • Вопрос задан
  • 1055 просмотров
Подписаться 1 Простой Комментировать
Пригласить эксперта
Ответы на вопрос 1
если посмотреть на пример, то для FixedSizeList в качестве дочернего компонента указывается не список строк, а одна строка, а в компоненте Row в качестве пропсов поступает индекс элемента, и по нему нужно отдавать нужные данные
const Row = ({ index, style }) => (
  <div style={style}>Row {index}</div>
);

Странное решение, ну уж какое есть
Ответ написан
Ваш ответ на вопрос

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

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