Bootstrap

react 中使用 swiper

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

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

直接食用

示例效果如下
请添加图片描述

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;
}

额外的自定控制组件 <SlideNextButton/>
要使用useSwiper 一定要将组件作为 <Swiper/>子组件使用

// 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>
  );
};
;