react 中使用 swiper

作者 : admin 本文共2534个字,预计阅读时间需要7分钟 发布时间: 2024-06-17 共1人阅读

最近项目中需要用到轮播图,我立马想起了 swiper ,那么本文就来带大家体验一下如何在 React 中使用这个插件,使用的是 函数组 + hooks 的形式。

需求非常简单,就是一个可以自动播放、点击切换的轮播图(跑马灯),可以同时展示n张图片,无限滚动。注意:如果是遇到纯文字的轮播效果,那我建议完全可以不用这么重的东西,直接使用 antd 中的Tab 组件或者干脆自己写也能达到效果
react 中使用 swiper插图

直接食用

示例效果如下
react 中使用 swiper插图(1)

1、安装依赖

npm i swiper

2、直接完成代码
需要什么就从'swiper/modules'中拓展,下面的几个满足大多数需求

// index.tsx
import { useState } from 'react';
import { Navigation, Pagination, Scrollbar } from 'swiper/modules';
import { Swiper, SwiperSlide } from 'swiper/react';
import 'swiper/css';
import 'swiper/css/navigation';
import 'swiper/css/pagination';
import 'swiper/css/scrollbar';

import './index.css'
import SlideNextButton from './SlideNextButton' //自定义控制按钮

export default function Index () => {
  const [ list ] = useState([ 1, 2, 3, 4, 5, 6, 7])

  return (
    <Swiper
      loop
      centeredSlides
      modules={[Navigation, Pagination, Scrollbar]}
      spaceBetween={50}
      slidesPerView={3}
      navigation // 对应 Navigation
      pagination={{ clickable: true }} // 对应 Pagination
      scrollbar={{ draggable: true }} // 对应 Scrollbar
      onSwiper={(swiper) => console.log(swiper)}
      onSlideChange={() => console.log('slide change')}
    >
      { list.map(item =>
        <SwiperSlide>
          <div className="card">
            { item }
          </div>
        </SwiperSlide>
      )}
      <SlideNextButton/>
    </Swiper>
  );
};

// index.css
.card{
  display: flex;
  justify-content: center;
  align-items: center;
  height: 200px;
  background: pink;
}

额外的自定控制组件
要使用useSwiper 一定要将组件作为 子组件使用

// SlideNextButton.tsx
import { useSwiper } from 'swiper/react';

export default function SlideNextButton() {
  const swiper = useSwiper();

  const onPrev = () => {
    swiper.slidePrev()
  }
  
  const onNext = () => {
    swiper.slideNext()
  }

  return (
    <div style={{ position: 'fixed' }}>
      <button onClick={onPrev}>prev</button>
      <button onClick={onNext}>next</button>
    </div>
  );
}

3、ref控制

	//可以直接使用ref绑定 swiper,然后调用其身上的方法
// index.tsx
import { useState, ussRef } from 'react';
import { Navigation, Pagination, Scrollbar } from 'swiper/modules';
import { Swiper, SwiperSlide } from 'swiper/react';
import 'swiper/css';
import 'swiper/css/navigation';
import 'swiper/css/pagination';
import 'swiper/css/scrollbar';
import './index.css'
import SlideNextButton from './SlideNextButton' //自定义控制按钮
export default function Index () => {
const swiperRef = ussRef()
const [ list ] = useState([ 1, 2, 3, 4, 5, 6, 7])
const onRest= () => {
let { swiper } = swiperRef.current //swiper实例可以调用其方法,具体的查询官网api
swiper.slideTo(0)
}
return (
<div>
<button onClick=onRest>回到第一个</button>
<Swiper
ref={swiperRef}
loop
centeredSlides
modules={[Navigation, Pagination, Scrollbar]}
spaceBetween={50}
slidesPerView={3}
navigation // 对应 Navigation
pagination={{ clickable: true }} // 对应 Pagination
scrollbar={{ draggable: true }} // 对应 Scrollbar
onSwiper={(swiper) => console.log(swiper)}
onSlideChange={() => console.log('slide change')}
>
{ list.map(item =>
<SwiperSlide>
<div className="card">
{ item }
</div>
</SwiperSlide>
)}
<SlideNextButton/>
</Swiper>
</div>
);
};
本站无任何商业行为
个人在线分享 » react 中使用 swiper
E-->