我试图在react js中将一个表与四个api集成在一起我已经使用了一个材料ui表我无法在表格中显示数据

如何解决我试图在react js中将一个表与四个api集成在一起我已经使用了一个材料ui表我无法在表格中显示数据

您好,我们正在尝试使用react js作为前端,nodejs作为后端以及postgress作为数据库来构建应用程序。该应用程序有一个表格,表格还具有可折叠表格功能。在表格中,我们有一个指向项目名称的链接,当我单击项目链接时,应打开折叠表,其中显示了有关类别的所有信息。 我在使用此代码时提到了以下代码,但无法显示表格数据

    const actionsStyles = (theme) => ({
      root: {
        flexShrink: 0,color: theme.palette.text.secondary,marginLeft: theme.spacing.unit * 2.5,},});
    
    class TablePaginationActions extends React.Component {
      handleFirstPageButtonClick = (event) => {
        this.props.onChangePage(event,0);
      };
    
      handleBackButtonClick = (event) => {
        this.props.onChangePage(event,this.props.page - 1);
      };
    
      handleNextButtonClick = (event) => {
        this.props.onChangePage(event,this.props.page + 1);
      };
    
      handleLastPageButtonClick = (event) => {
        this.props.onChangePage(
          event,Math.max(0,Math.ceil(this.props.count / this.props.rowsPerPage) - 1)
        );
      };
    
      render() {
        const { classes,count,page,rowsPerPage,theme } = this.props;
    
        return (
          <div className={classes.root}>
            <IconButton
              onClick={this.handleFirstPageButtonClick}
              disabled={page === 0}
              aria-label="First Page"
            >
              {theme.direction === "rtl" ? <LastPageIcon /> : <FirstPageIcon />}
            </IconButton>
            <IconButton
              onClick={this.handleBackButtonClick}
              disabled={page === 0}
              aria-label="Previous Page"
            >
              {theme.direction === "rtl" ? (
                <KeyboardArrowRight />
              ) : (
                <KeyboardArrowLeft />
              )}
            </IconButton>
            <IconButton
              onClick={this.handleNextButtonClick}
              disabled={page >= Math.ceil(count / rowsPerPage) - 1}
              aria-label="Next Page"
            >
              {theme.direction === "rtl" ? (
                <KeyboardArrowLeft />
              ) : (
                <KeyboardArrowRight />
              )}
            </IconButton>
            <IconButton
              onClick={this.handleLastPageButtonClick}
              disabled={page >= Math.ceil(count / rowsPerPage) - 1}
              aria-label="Last Page"
            >
              {theme.direction === "rtl" ? <FirstPageIcon /> : <LastPageIcon />}
            </IconButton>
          </div>
        );
      }
    }
    
    TablePaginationActions.propTypes = {
      classes: PropTypes.object.isRequired,count: PropTypes.number.isRequired,onChangePage: PropTypes.func.isRequired,page: PropTypes.number.isRequired,rowsPerPage: PropTypes.number.isRequired,theme: PropTypes.object.isRequired,};
    
    const TablePaginationActionsWrapped = withStyles(actionsStyles,{
      withTheme: true,})(TablePaginationActions);
    
    let counter = 0;
    function createData(
      project,Assessment_Completion,Achieved_Percentage,Level
    ) {
      counter += 1;
      return {
        id: counter,project,Level,};
    }
    
    const styles = (theme) => ({
      root: {
        width: "100%",marginTop: theme.spacing.unit * 3,table: {
        minWidth: 500,tableWrapper: {
        overflowX: "auto",searchField: {
        margin: "10px",borderRadius: "3px",outline: "none",border: "1px solid gray",padding: "5px",display: "flex",justifyContent: "flex-end",alignItems: "flex-end",});
    
    class ViewProject extends React.Component {
      constructor(props) {
        super(props);
        this.state = {
          rows: [].sort((a,b) => (a.calories < b.calories ? -1 : 1)),page: 0,rowsPerPage: 5,filter: "",open: false,expanded: false,rowIndex: null,isEdit: false,};
      }
    
      async componentDidMount() {
        await this.props.getallprojects();
        console.log();
        await this.props.getparticular_project_details();
        await this.props.getall_active_project_details();
        await this.props.get_all_categories_regarding_project();
      }
    
      handleOnChangeSelectValue = (e) => {
        this.setState({
          projectname: e.target.value,});
      };
    
      handleClick = (index) => {
        this.setState((state) => ({
          open: !state.open,expanded: !state.expanded,rowIndex: index,}));
      };
    
      handleChange = (event) => {
        this.setState({ filter: event.target.value });
      };
    
      handleChangePage = (event,page) => {
        this.setState({ page });
      };
    
      handleChangeRowsPerPage = (event) => {
        this.setState({ page: 0,rowsPerPage: event.target.value });
      };
    
      render() {

        const {
          getallprojectsRes,getparticular_project_detailsRes,getall_active_project_detailsRes,get_all_categories_regarding_projectRes,} = this.props;
        const { classes } = this.props;
        const { rowIndex,open,expanded } = this.state;
        const { rows,page } = this.state;
        const emptyRows =
          rowsPerPage - Math.min(rowsPerPage,rows.length - page * rowsPerPage);
    
        const { filter } = this.state;

//I have defined variables to call api inside render
    
        const gaplowercasedFilter = filter.toLowerCase();
        const gapFilteredData =
          getallprojectsRes &&
          getallprojectsRes.data &&
          getallprojectsRes.data.filter((item) => {
            return Object.keys(item).some((key) =>
              item[key].toString().toLowerCase().includes(gaplowercasedFilter)
            );
          });
    
        const gaapdlowercasedFilter = filter.toLowerCase();
        const gaapdFilteredData =
          getall_active_project_detailsRes &&
          getall_active_project_detailsRes.data &&
          getall_active_project_detailsRes.data.filter((item) => {
            return Object.keys(item).some((key) =>
              item[key].toString().toLowerCase().includes(gaapdlowercasedFilter)
            );
          });
    
        const gacrlowercasedFilter = filter.toLowerCase();
        const gacrFilteredData =
          get_all_categories_regarding_projectRes &&
          get_all_categories_regarding_projectRes.data &&
          get_all_categories_regarding_projectRes.data.filter((item) => {
            return Object.keys(item).some((key) =>
              item[key].toString().toLowerCase().includes(gacrlowercasedFilter)
            );
          });
    
        const gppdlowercasedFilter = filter.toLowerCase();
        const gppdFilteredData =
          getparticular_project_detailsRes &&
          getparticular_project_detailsRes.data &&
          getparticular_project_detailsRes.data.filter((item) => {
            return Object.keys(item).some((key) =>
              item[key].toString().toLowerCase().includes(gppdlowercasedFilter)
            );
          });
    
        return (
          <div>
            <div>
              <h3>View Projects</h3>
            </div>
    
            <Paper className={classes.root}>
              <div className={classes.tableWrapper}>
                <input
                  value={filter}
                  onChange={this.handleChange}
                  placeholder="Search here..."
                  className={classes.searchField}
                />
                <Table className={classes.table}>
                  <TableHead>
                    <TableRow>
                      <TableCell>Project </TableCell>
                      <TableCell align="right">Category</TableCell>
                      <TableCell align="right">Assessment Completion %</TableCell>
                      <TableCell align="right">Achieved Percentage</TableCell>
                      <TableCell align="right">Level</TableCell>
                    </TableRow>
                  </TableHead>
                  <TableBody>
                    <TableRow>
                      <TableCell
                        component="th"
                        scope="row"
                        button
                        onClick={() => this.handleClick(index)}
                      >
                        {gapFilteredData &&
                          gapFilteredData
                            .slice(
                              page * rowsPerPage,page * rowsPerPage + rowsPerPage
                            )
                            .map(
                              (row,index) => (
                                row.name,index === rowIndex && open ? (
                                  <ExpandLess />
                                ) : (
                                  <ExpandMore />
                                )
                              )
                            )}
    
                        {gacrFilteredData &&
                          gacrFilteredData
                            .slice(
                              page * rowsPerPage,page * rowsPerPage + rowsPerPage
                            )
                            .map((row,index) => (
                              <Collapse
                                in={index === rowIndex && expanded}
                                timeout="auto"
                                unmountOnExit
                              >
                                <Typography
                                  variant="h6"
                                  gutterBottom
                                  component="div"
                                ></Typography>
                                <Table>
                                  <Table size="small" aria-label="purchases">
                                    <TableHead>
                                      <TableRow>
                                        <TableCell align="right">
                                          Category
                                        </TableCell>
                                        <TableCell align="right">
                                          Assessment Completion %
                                        </TableCell>
                                        <TableCell align="right">
                                          Achieved Percentage
                                        </TableCell>
                                        <TableCell align="right">Level</TableCell>
                                      </TableRow>
                                      <TableBody>
                                        <TableRow>
                                          <TableCell component="th" scope="row">
                                            {row.category}
                                          </TableCell>
                                          <TableCell align="right">
                                            {row.Assessment_Completion}
                                          </TableCell>
                                          <TableCell align="right">
                                            {row.Achieved_Percentage}
                                          </TableCell>
                                          <TableCell align="right">
                                            {row.Level}
                                          </TableCell>
                                        </TableRow>
                                      </TableBody>
                                    </TableHead>
                                  </Table>
                                </Table>
                              </Collapse>
                            ))}
                      </TableCell>
    
                      {gppdFilteredData &&
                        gppdFilteredData
                          .slice(
                            page * rowsPerPage,page * rowsPerPage + rowsPerPage
                          )
                          .map((row,index) => (
                            <>
                              <TableCell align="right">
                                {row.Assessment_Completion}
                              </TableCell>
                              <TableCell align="right">
                                {row.Achieved_Percentage}
                              </TableCell>
                              <TableCell align="right">{row.Level}</TableCell>
                            </>
                          ))}
                    </TableRow>
    
                    {emptyRows > 0 && (
                      <TableRow style={{ height: 48 * emptyRows }}>
                        <TableCell colSpan={6} />
                      </TableRow>
                    )}
                  </TableBody>
                  <TableFooter>
                    <TableRow>
                      <TablePagination
                        rowsPerPageOptions={[5,10,25]}
                        colSpan={9}
                        count={rows.length}
                        rowsPerPage={rowsPerPage}
                        page={page}
                        SelectProps={{
                          native: true,}}
                        onChangePage={this.handleChangePage}
                        onChangeRowsPerPage={this.handleChangeRowsPerPage}
                        ActionsComponent={TablePaginationActionsWrapped}
                      />
                    </TableRow>
                  </TableFooter>
                </Table>
              </div>
            </Paper>
          </div>
        );
      }
    }
    
    enter code here

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-