RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1588750
Accepted
Miha
Miha
Asked:2024-07-29 18:16:18 +0000 UTC2024-07-29 18:16:18 +0000 UTC 2024-07-29 18:16:18 +0000 UTC

动态改变中央幻灯片的宽度

  • 772

我正在使用 swiper 和 next.js 13 编写一个轮播,但是我遇到了一个问题,当我更改活动幻灯片(位于中间)的宽度时,该幻灯片不在中间,而是稍微偏向一侧。

我使用 ResizeObserver 来跟踪所选幻灯片宽度的变化,但在这种情况下,幻灯片无法平滑地移动到中心并被传送。如何制作更改所选块宽度的平滑动画(不使用比例)?

const Carousel: React.FC = () => {
  const [swiperRef, setSwiperRef] = useState<SwiperClass>(null);
  const [clickedSlide, setClickedSlide] = useState<number>();

  const handleClickSlide = (swiper: SwiperClass) => {
    setClickedSlide(swiper.clickedIndex);
  };

  return (
    <ClickAwayListener onClickAway={() => setClickedSlide(undefined)} mouseEvent="onMouseDown">
      <div className={classNames(style['swiper-container'])}>
        <div className={style['swiper-prev']}>&larr;</div>

        <Swiper
          onSwiper={setSwiperRef}
          onClick={handleClickSlide}
          direction="horizontal"
          slidesPerView="auto"
          speed={600}
          slideToClickedSlide
          centeredSlides
          resizeObserver
          freeMode
          navigation={{
            nextEl: '.' + style['swiper-next'],
            prevEl: '.' + style['swiper-prev'],
          }}
          mousewheel={{
            sensitivity: 0.5,
          }}
          modules={[Navigation, Mousewheel, Manipulation]}
        >
          {
            slides.map((slide) => {
              const active = clickedSlide == index;

              return (
                <SwiperSlide className={classNames(style['swiper-slide'], active && style['swiper-slide-active'])}>
                  <SlideComponent slide={slide} active={active} swiper={swiperRef} />
                </SwiperSlide>
              );
            })
          }
        </Swiper>

        <div className={style['swiper-next']}>  &rarr;</div>
      </div>
    </ClickAwayListener>
  );
};

SlideComponent.tsx

const SlideComponent = React.forwardRef<HTMLDivElement, MapCarouselSlideProps>(({
  job,
  className,
  active,
  swiper,
  ...props
}, ref) => {
  const slide = useRef<HTMLDivElement>(null);

  useImperativeHandle(ref, () => slide.current!, []);

  useEffect(() => {
    if (!slide.current) {
      return;
    }

    const observer = new ResizeObserver(() => swiper.update());
    observer.observe(slide.current);

    return () => observer.disconnect();
  }, [active]);

  return (
    <div ref={slide} className={classNames(style['slide-component'], className)} {...props} >
      text
    </div>
  );
});

CSS

.swiper-slide {
  flex-basis: 280px;
  width: 280px;
  overflow: hidden;
  padding: 16px;
  transition: flex-basis 500ms ease-in-out !important;
}

.swiper-slide-active {
  flex-basis: 520px;
  width: 520px;
}

在寻找解决方案时,我在 swiper 项目的 git 中遇到了问题:
add width to swiper-slide-activemakescenteredSlidestofail

reactjs
  • 1 1 个回答
  • 16 Views

1 个回答

  • Voted
  1. Best Answer
    Miha
    2024-08-13T17:21:15Z2024-08-13T17:21:15Z

    用拐杖固定它

    添加了样式map-carousel-wrapper

    .map-carousel-wrapper {
      align-items: flex-end;
      transition: all 300ms linear !important;
    }
    

    以及ResizeObserver每张幻灯片

      useEffect(() => {
        if (!slide.current) {
          return;
        }
    
        const observer = new ResizeObserver(() => swiper.update());
        observer.observe(slide.current);
    
        return () => observer.disconnect();
      }, [active]);
    
    • 0

相关问题

  • 如果图像在道具中,如何使背景图像做出反应?

  • 项目未显示

  • 引发错误:InvalidTokenError: Invalid token specified: Cannot read property 'replace' of undefined

  • 如何在没有 node.js 的情况下运行 react.js 应用程序

  • 如何从 React Native 中的导航堆栈中清除上一个屏幕?

  • 为什么渲染后会触发 Click 事件?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5