0
点赞
收藏
分享

微信扫一扫

触摸滑动插件:Swiper

中文网:https://www.swiper.com.cn/
GitHub:https://github.com/nolimits4web/swiper

swiper是什么?

基本用法

在页面中引入这两个文件之后首先要写基本的html结构
下面所有的使用方式基于swiper 4.x

<div class="swiper-container">
  <div class="swiper-wrapper">
    <div class="swiper-slide">Slide 1</div>
    <div class="swiper-slide">Slide 2</div>
    <div class="swiper-slide">Slide 3</div>
    <div class="swiper-slide">Slide 4</div>
    <div class="swiper-slide">Slide 5</div>
    <div class="swiper-slide">Slide 6</div>
    <div class="swiper-slide">Slide 7</div>
    <div class="swiper-slide">Slide 8</div>
    <div class="swiper-slide">Slide 9</div>
    <div class="swiper-slide">Slide 10</div>
  </div>
</div>

类名为swiper-container 是滑动轮播插件的包裹器,类似于一个mask,一个窗口,swiper-wrapper是一个按照一定顺序排列的所有轮播图的集合,在默认情况下是左右排列,当鼠标或者触屏进行操作的时候,改变的是这个元素的位置,而达到轮播的效果。swiper-slide则是每个轮播图元素,在写好基本html结构之后,需要对这个轮播图进行初始化

<script>
  var swiper = new Swiper('.swiper-container');
</script>

这样就能生成一个默认的轮播图,可以用鼠标或者触摸屏来进行左右的滑动

添加分页与导航

<div class="swiper-container">
  <div class="swiper-wrapper">...</div>
  <div class="swiper-button-next"></div>
  <div class="swiper-button-prev"></div>
</div>

在这里swiper-button-nextswiper-button-prev都是指定好的按钮,下一个按钮会垂直居中并且靠右边,上一个按钮会垂直居中靠右边,当然也能自己指定按钮。

var swiper = new Swiper('.swiper-container',{
  navigation:{
    nextEl: '.swiper-button-next',
    prevEl: '.swiper-button-prev',
  }
});

在初始化函数中添加按钮元素。这样就能生成一个有导航按钮的轮播图了

siwper导航

添加分页的方式和导航按钮非常类似

html:

<div class="swiper-container">
  <div class="swiper-wrapper">
    ...
  </div>
  <!-- 分页 -->
  <div class="swiper-pagination"></div>
  <!--导航按钮-->
  <div class="swiper-button-next"></div>
  <div class="swiper-button-prev"></div>
</div>

在初始化的时候加入分页元素

js:

var swiper = new Swiper('.swiper-container', {
  pagination: {
    el: '.swiper-pagination',
  },
  navigation:{
    nextEl: '.swiper-button-next',
    prevEl: '.swiper-button-prev',
  }
});

这样就能生成有分页又有导航的轮播图了

循环与自动轮播:

js:
在初始化的时候加入

var swiper = new Swiper('.swiper-container', {
  //分页
  pagination: {
    el: '.swiper-pagination',
  },
  //导航按钮
  navigation:{
    nextEl: '.swiper-button-next',
    prevEl: '.swiper-button-prev',
  },
  //自动轮播
  autoplay: {
    delay: 2500,//时间 毫秒
    disableOnInteraction: false,//用户操作之后是否停止自动轮播默认true 
  },
  loop:true,//循环 最后面一个往后面滑动会滑到第一个
});

其他常用属性
分页用进度条代替

var swiper = new Swiper('.swiper-container', {
  pagination: {
    el: '.swiper-pagination',
    type: 'progressbar',//将分页的类型改为进度条就行
  },
  navigation:{
    nextEl: '.swiper-button-next',
    prevEl: '.swiper-button-prev',
  },
  autoplay: {
    delay: 2500,
    disableOnInteraction: false,
  },
});
举报

相关推荐

0 条评论