首页 > 解决方案 > 在反应轮播中添加幻灯片动画

问题描述

我正在尝试使用纯 JS 和 React重新制作轮播react-bootstrap

到目前为止,我的轮播每隔几秒钟就会自动切换到下一张幻灯片并循环回到开头。它还可以在单​​击按钮时显示特定的轮播幻灯片。

但是,我无法复制从右到左的滑动动画,因为我正在使用slice渲染我的幻灯片。我将如何编辑我的代码以包含像引导程序这样的滑动动画?

import React, { useState, useEffect } from "react";
import "./styles.css";

const slides = [
  {
    src:
      "https://res.cloudinary.com/tpostr/image/upload/v1553865338/paparouna/IMG_7638-01.jpg",
    alt: "slide 1",
    caption: "slide 1"
  },
  {
    src:
      "https://res.cloudinary.com/tpostr/image/upload/v1553865338/paparouna/IMG_7621-01.jpg",
    alt: "slide 2",
    caption: "slide 2"
  },
  {
    src:
      "https://res.cloudinary.com/tpostr/image/upload/v1553865337/paparouna/IMG_7615-01.jpg",
    alt: "slide 3",
    caption: "slide 3"
  }
];

export default function App() {
  const [start, setStart] = useState(0);
  const [end, setEnd] = useState(1);

  const first = () => {
    setStart(0);
    setEnd(1);
  };
  const second = () => {
    setStart(1);
    setEnd(2);
  };
  const third = () => {
    setStart(2);
    setEnd(3);
  };

  useEffect(() => {
    const timeout = setTimeout(() => {
      setStart((start) => start + 1);
      setEnd((end) => end + 1);
    }, 3000);

    if (end === slides.length + 1) {
      setStart(0);
      setEnd(1);
    }

    return () => {
      clearTimeout(timeout);
    };
  }, [start, end]);
  return (
    <div className="App">
      <h1>Hello CodeSandbox</h1>
      <h2>Start editing to see some magic happen!</h2>
      {slides.slice(start, end).map((slide, i) => (
        <div key={i}>
          <img src={slide.src} alt={slide.alt} />
          <p>{slide.caption}</p>
          <button onClick={first}>first</button>
          <button onClick={second}>second</button>
          <button onClick={third}>third</button>
        </div>
      ))}
      <p>{start} start</p>
      <p>{end} end</p>
    </div>
  );
}

我的密码箱

标签: javascriptreactjs

解决方案


只要您的三张图片没有一起显示在 html 页面中,您就无法对它们进行幻灯片动画处理。你为什么不把它们全部展示出来并像普通滑块一样在它们的位置之间切换?

如果通过更改src属性来更改图像,那么动画就没有办法了。请参考这个答案,然后从那里继续。

很抱歉让您失望了……玩得开心!

但这是一个纯 js 滑块链接


推荐阅读