主頁 > .NET開發 > react沒有渲染所有行,只是渲染了一個物件并重復

react沒有渲染所有行,只是渲染了一個物件并重復

2022-11-10 11:53:44 .NET開發

它應該將所有行填充到表中(這些行來自 api 是一個物件陣列)目前的問題是只渲染陣列的最后一個物件,我不知道為什么它會不斷重復,如您所見它僅加載 1 個物件然后重復的螢屏截圖,這就是所有行具有相同值的原因。

順便說一句,來自 api 的行或資料是一個物件陣列/

也許有人對我們如何解決這個問題有想法。謝謝。

react 沒有渲染所有行,只是渲染了一個物件并重復

#rows from the api result from the console log 這是饋送到網格的行 react 沒有渲染所有行,只是渲染了一個物件并重復

#反應代碼

export const StyledDataGrid = styled(DataGrid)`
    .MuiDataGrid-row: nth-of-type(odd) {
      background: #E3E0E0
    }
    .MuiDataGrid-cell {
      border-right: 1px solid #C4C4C4;
    }
    .MuiDataGrid-columnHeader  {
      border-right: 1px solid #C4C4C4;
    }
    .MuiDataGrid-columnSeparator--sideRight {
      display: none
    }
    .MuiDataGrid-columnHeaderTitleContainer {
      justify-content: space-between;
    }
    .MuiDataGrid-iconButtonContainer  {
      visibility: visible;
      width: auto;
    }
`;

const PortfolioPage: FC = () => {
  const router = useRouter();
  const dispatch = useAppDispatch();
  const { isPending, isError, isSuccess, grid, isSaveSuccess } = useAppSelector(
    (state) => state.region
  );
  const [snackbarOpen, setSnackbarOpen] = useState<boolean>(false);

  const [selectedRow, setSelectedRow] = useState<IRegional | null>(null)

  const rows = grid ? grid.items : [];

  console.log('rows' , rows)


  const fetchGridItems = () => {
     const payload: IPageListApiRequestPayload = {
        accountId: 1,
        sortKey: JSON.stringify([]),
        sortOrder: JSON.stringify([]),
        page: 1,
        pageSize: 100,
        searchString: '',
      };
      dispatch(getRegionGrid(payload));
  }
  useEffect(() => {
    // Save success
    if (isSaveSuccess) {
      setSnackbarOpen(true);
      fetchGridItems();
    }
  }, [isSaveSuccess])
  useEffect(() => {
    if (router.isReady) {
      fetchGridItems();
    }
  }, [router.isReady]);

  const renderList = (data: IEmail) => (
    <div style={{display: 'block'}}>
        <div>Full Name: {data.firstName} {data.lastName}</div>
        <div>Email Address: {data.emailAddress}</div>
    </div>
  )

  const columns: GridColDef[] = [
    {
      field: "associateDirectorofConstructionOps",
      headerName: "Associate Director of Construction Ops",
      minWidth: 300,
      flex: 0.16,
      disableColumnMenu: true,
      renderCell: (params: GridRenderCellParams<string>) => (
        <>
           {
             params.row.associateDirectorofConstructionOps ? params.row.associateDirectorofConstructionOps.map((prop: IEmail) => renderList(prop))
              : null
           }
        </>
      ),
    },
  ];
  const fixedColumnLeft: GridColDef[] = [
    {
      field: "regionName",
      headerName: "Region Division",
      flex: 0.08,
      minWidth: 100,
      disableColumnMenu: true,
    },
    {
      field: "subRegionName",
      headerName: "Sub-Region",
      flex: 0.15,
      minWidth: 50,
      disableColumnMenu: true,
    },
    {
      field: "marketName",
      headerName: "Market",
      flex: 0.08,
      minWidth: 50,
      disableColumnMenu: true,
    },
  ];
  const fixedColumnRight: GridColDef[] = [
    {
      field: "action",
      disableColumnMenu: true,
      sortable: false,
      renderHeader: () => <></>,
      renderCell: (params: GridRenderCellParams<string>) => (
        <div
          style={{
            color: "rgb(110 110 110)",
            display: "flex",
            justifyContent: "space-between",
          }}
        >
          <EditIcon onClick={() => handleClickOpen(params)} />
        </div>
      ),
    },
  ];
  const [open, setOpen] = React.useState<boolean>(false);
  const handleClickOpen = (data: any) => {
    setSelectedRow(data.row);
    setOpen(true);
  };

  const handleClose = () => {
    setOpen(false);
  };
  return (
    <Box sx={{ height: "100vh", background: "#EEEAEA" }}>
      <Snackbar
        open={snackbarOpen}
        autoHideDuration={3000}
        onClose={() => setSnackbarOpen(false)}>
        <Alert onClose={() => setSnackbarOpen(false)} severity="success" sx={{ width: '100%' }}>
              Successfully saved!
        </Alert>
      </Snackbar>
      <EditProperties open={open} handleClose={handleClose} selectedRow={selectedRow} />
      <DashboardWrapper seoProps={{
        title: "PIM | Regions",
        }}
        title="Properties"
        mainClass="properties-page">
        {isError ? <div>Error Loading Regions!</div> : ""}
        {isPending ? <>Loading Regions...</> : ""}
        {isSuccess ? (
        <>
            <div
              style={{
                display: "flex",
                justifyContent: "space-between",
                width: "636px",
                height: "56px",
                background: "rgba(37, 36, 41, 0.9)",
                padding: "8px 16px 8px 8px",
                borderBottomRightRadius: "30px",
              }}
            >
              <Input
                size="small"
                style={{
                  width: "461px",
                  height: "40px",
                  background: "#FFFFFF",
                  borderRadius: "4px",
                  outline: "none",
                }}
                placeholder="Search  by typing property name or address"
                startAdornment={
                  <InputAdornment position="start">
                    <SearchIcon />
                  </InputAdornment>
                }
              />
              <Button
                variant="contained"
                style={{ textTransform: "capitalize" }}
              >
                Search
              </Button>
              <div
                style={{
                  display: "flex",
                  color: "#FFFFFF",
                  flexDirection: "column",
                  justifyContent: "space-between",
                  alignItems: "center",
                  marginRight: "10px",
                }}
              >
                <TuneIcon style={{ fontSize: "32px" }} />
                <span style={{ fontSize: "10px", marginTop: "-5px" }}>
                  Filters
                </span>
              </div>
            </div>
            <TableContainer component={Paper} style={{ marginTop: "24px" }}>
              <div
                style={{
                  borderBottom: "1px solid #C4C4C4",
                  padding: "16px",
                  display: "flex",
                  justifyContent: "space-between",
                  background: "#FFFFFF",
                  height: "72px",
                }}
              >
                <label
                  style={{
                    fontWeight: "600",
                    fontSize: "24px",
                    color: "#252429",
                    alignSelf: "center",
                  }}
                >
                  {" "}
                  Regions{" "}
                </label>
                <div
                  style={{
                    alignSelf: "center",
                    color: "#C4C4C4",
                    display: "flex",
                    fontSize: "16px",
                  }}
                >
                  <IosShareIcon style={{ marginRight: "14px" }} />
                  Export
                </div>
              </div>
              {/* Table container */}
              <div style={{position: "relative", display: 'flex', justifyContent: 'space-between'}}>
                  {/* Left table */}
                  <Box
                    sx={{ boxShadow: 5 }}
                    style={{
                      width: "20%",
                   
                      zIndex: 99,
                      overflow: "hidden",
                      background: "#FFFFFF",
                    }}
                  >
                    <StyledDataGrid
                      autoHeight 
                      getRowId={(row) => row.accountId}
                      hideFooterPagination={true}
                      components={{
                        ColumnSortedAscendingIcon: UnfoldMoreIcon,
                        ColumnSortedDescendingIcon: UnfoldMoreIcon,
                      }}
                      rows={rows}
                      columns={fixedColumnLeft}
                      disableSelectionOnClick
                      experimentalFeatures={{ newEditingApi: true }}
                    />
                  </Box>

                  {/* Center table */}
                <div style={{overflow: 'hidden', width: '70%'}}>
                  <div style={{ width: '2000px', margin: 'auto', overflow: "hidden"}} >
                    <StyledDataGrid
                      autoHeight 
                      getRowId={(row) => row.accountId}
                      components={{
                        ColumnSortedAscendingIcon: UnfoldMoreIcon,
                        ColumnSortedDescendingIcon: UnfoldMoreIcon,
                      }}
                      rows={rows}
                      columns={columns}
                      pageSize={100}
                      rowsPerPageOptions={[10, 20, 50, 100]}
                      disableSelectionOnClick
                      experimentalFeatures={{ newEditingApi: true }}
                    />
                  </div>
                </div>

                  {/* Right table */}
                  <Box
                    sx={{ boxShadow: 5 }}
                    style={{
                      width: "10%",
                      zIndex: 99,
                      overflow: "hidden",
                      background: "#FFFFFF",
                    }}
                  >
                    <StyledDataGrid
                      autoHeight 
                      getRowId={(row) => row.accountId}
                      hideFooterPagination={true}
                      components={{
                        ColumnSortedAscendingIcon: UnfoldMoreIcon,
                        ColumnSortedDescendingIcon: UnfoldMoreIcon,
                      }}
                      rows={rows}
                      columns={fixedColumnRight}
                      disableSelectionOnClick
                      experimentalFeatures={{ newEditingApi: true }}
                    />
                  </Box>
              </div>
            </TableContainer>
            {/* <ActionButtonContainer
              btnNameOne="Property"
              btnNameTwo="Properties"
              btnIconOne={<UploadFileIcon />}
              btnIconTwo={<AddIcon />}
            /> */}
          </>
        ) : (
          ""
        )}
      </DashboardWrapper>
    </Box>

uj5u.com熱心網友回復:

是的,正因為如此

react 沒有渲染所有行,只是渲染了一個物件并重復

這條線是所有這些問題的原因

期望表中的DataGrid每一行都有一個唯一的鍵

所以它在問你在哪里可以找到那個唯一的鍵

你告訴它它可以在accountId道具里面找到它。

這是不準確的,因為它有重復

通常這應該是 id,但在你的情況下它到處都是 null。

如果來自你的 API 的資料源有一個名為“id”的屬性,DataGrid如果你沒有設定這個屬性,MUI 會自動使用它getRowId

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/530700.html

標籤:javascript反应打字稿

上一篇:通過多個引數(輸入)過濾物件

下一篇:TSLint:禁止使用非箭頭函式

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more