首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React嵌套的.map()不返回任何元素?

React嵌套的.map()不返回任何元素?
EN

Stack Overflow用户
提问于 2022-10-30 18:40:12
回答 1查看 48关注 0票数 0

我正在尝试以特定的网格格式呈现一个嵌套的图像数组,其中列的数量被传递给组件。

我有一个充满图像src的2D数组,我首先通过outerArr映射来创建列(这是预期的)。但是当我试图通过内部元素映射时,什么都不会返回。我玩过显式或隐式回报,但似乎无法做到这一点。而且,在检查元素时,我可以看到列元素中没有呈现任何内容。

如果我只映射了数组()的一个维度,我就可以呈现jsx,但如果它是嵌套的,则不能。嵌套映射中是否有我缺少的元素?

代码语言:javascript
复制
let NFTPayload = [
  NFT1,
  NFT2,
  NFT3,
  NFT4,
  NFT1,
  NFT2,
  NFT3,
  NFT4,
  NFT1,
  NFT2,
  NFT3,
  NFT4,
  NFT1,
  NFT2,
  NFT3,
  NFT4,
  NFT1,
  NFT2,
  NFT3,
];
const NFTGallery = (props) => {
  // state is set to an empty array, ready to store the NFT payload
  const [NFTPayload, setNFTPayload] = useState([]);
  const itemCount = NFTPayload.length - 1;
  const rowCount = Math.round(itemCount / props.columnCount);
  let nftArr = [...Array(props.columnCount)].map((e) => Array(rowCount));
  console.log('Row count is ', rowCount);
  console.log('Item length count is ', itemCount);
  console.log('Column count is ', props.columnCount);
  //const rowCount = itemCount /;

  useEffect(() => {
    setNFTPayload(smartContractArrayOfNFTs);
  }, []);

  useEffect(() => {
    NFTPayload.reverse();
    for (let i = 0; i < props.columnCount; i++) {
      let outerCounter = 0;
      for (let j = 0; j < rowCount; j++) {
        nftArr[i][j] = 
        NFTPayload[outerCounter];
        outerCounter++;
      }
    }
  }, [NFTPayload]);

  return (
    <>
      <section className={styling.testContainer}>
        {nftArr && 
        nftArr.map((ele, outerIdx) => (
          <div key={outerIdx} className={styling.testColumn}>
            {
              ele.map((item, innerIdx) => (
                return(
                <img src={item}></img>
                )
              ))
            }
          </div>
        ))}
      </section>
    </>
  );
};

export default NFTGallery;
EN

回答 1

Stack Overflow用户

发布于 2022-10-30 19:09:48

您看到的问题是,每当依赖项更改时,您都会再次更改它,从而使用useEffect触发无限循环。难道不可能从deps中删除NFTPayload并仅在挂载上计算吗?

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74255775

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档