javascript - Material UI Carousel 上的多个元素

标签 javascript css reactjs material-ui

我正在使用以下 Material UI Carousel图书馆,我无法理解如何为轮播创建多个元素。
我在文档中搜索过,那里没有解决方案,尝试通过定义宽度来使用 CSS 进行操作,如下所示:

  .item{
    margin: 0 auto;
    text-align: center;
    width: 30%;
  }
也没有用。
这是我的代码:
 function Home() {
  var items = [
    {
        name: "Pizza Begin",
        link: "pizza-begin.co.il",
        image: Begin
    },
    {
        name: "Mia Luz",
        link: "mia-luz.com",
        image: Mia
    },
    {
        name: "Nuda Swim",
        link: "nudaswim.com"
    }
   ];


   return(<>
    <Carousel navButtonsAlwaysInvisible={true} animation="slide" activeIndicatorIconButtonProps={{className: "activeIndicator"}}>
        {
            items.map( (item, i) => <Item key={i} item={item} /> )
        }
    </Carousel>

</>);
}

function Item(props)
{
    return (
        <Paper className="item">
            <img className="imageCarousel" src={props.item.image} alt={props.item.name} />
            <h2 onClick={() => { window.location.href = props.item.link; }}>{props.item.name}</h2>
        </Paper>
    )
}

export default Home;
现在每张幻灯片包含一个元素,我的目标是在每张幻灯片上达到 3 个元素。
如何使用 Material UI Carousel 在一张幻灯片中使用多个元素?
Codesandbox

最佳答案

沙洛姆!
问题出在 Carousel 组件内部。
我是 Material UI 的新手,但似乎每个数组元素在 slider 上都有一个“页面”。
所以我所做的,它给了我你正在寻找的结果,看起来像这样:

    const sliderItems: number = data.length > 3 ? 3 : data.length;
  const items: Array<any> = [];

  for (let i = 0; i < data.length; i += sliderItems) {
    if (i % sliderItems === 0) {
      items.push(
        <Card raised className="Banner" key={i.toString()}>
          <Grid container spacing={0} className="BannerGrid">
            {data.slice(i, i + sliderItems).map((da, index) => {
              return <SubCategory key={index.toString()} item={da} />;
            })}
          </Grid>
        </Card>
      );
    }
  }
  return (
    <Carousel animation="slide" autoPlay={false} cycleNavigation timeout={300}>
      {items}
    </Carousel>
  );
};
我为每个 slider 选择了 3 个元素。
items 数组包含卡片数组。

关于javascript - Material UI Carousel 上的多个元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66861638/

相关文章:

javascript - 如何将修改后的 prop 发送到 redux store?

javascript - removeChild "Node was not found"- 无法解决

javascript - 需要使用 LINQ JS 迭代多维数组中的值

css - html-pdf:如何确保图像不跨越分页符

reactjs - 检查 React 组件的类型

javascript - setState 不适用于多个 onClick 函数

javascript - 具有任意键的对象的 typescript 接口(interface)?

javascript - 编辑列表中的相应元素

jquery - 将元素放在进度条顶部的另一个元素的右侧

javascript - 如何将 JSON 中的数据显示到 html 表中