swiper 自动图片无限轮播实现代码

 更新时间:2018年05月21日 23:14:34   投稿:mdxy-dxy  
今天移动端正好需要图片触摸滑动效果实现代码,基于swiper实现,需要的朋友可以参考下

完整代码

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>

 <link rel="stylesheet" href="swiper/css/swiper-3.4.2.min.css" rel="external nofollow" >
 <script src="swiper/js/swiper-3.4.2.min.js"></script>
 <style type="text/css">
  
  .swiper-container {
   width: 900px;
   height: 300px;
  }
 </style>
</head>
<body>
<div class="swiper-container">
 <div class="swiper-wrapper">
  <div class="swiper-slide box1"><img src="img/a.jpg"></div>
  <div class="swiper-slide box2" ><img src="img/b.jpg"></div>
  <div class="swiper-slide box3"><img src="img/c.jpg"></div>
 </div>
 <!-- 如果需要分页器 -->
 <div class="swiper-pagination"></div>

 <!-- 如果需要导航按钮 -->
 <div class="swiper-button-prev"></div>
 <div class="swiper-button-next"></div>

 <!-- 如果需要滚动条 -->
  <!--<div class="swiper-scrollbar"></div>-->
</div>

</div>
<script>
 var mySwiper = new Swiper ('.swiper-container', {
  direction: 'horizontal',
  loop: true,

  // 如果需要分页器
  pagination: '.swiper-pagination',

  // 如果需要前进后退按钮
  nextButton: '.swiper-button-next',
  prevButton: '.swiper-button-prev',
  autoplay : 1000,
  speed:100,
  // 如果需要滚动条
//   scrollbar: '.swiper-scrollbar',
  effect : 'coverflow',
  slidesPerView: 3,
  centeredSlides: true,
  coverflow: {
   rotate: 30,
   stretch: 10,
   depth: 60,
   modifier: 2,
   slideShadows : true
  }
 })
</script>

</body>
</html>

如何使用swiper写轮播

之前大家都写过轮播图吧,相信在写轮播图的过程中也因为当中的某些细节烦恼过吧,接下来我给大家讲述一个方便快捷的轮播图吧!

Swiper常用于移动端网站的内容触摸滑动

1.第一步先引入css---swiper.css插件和JQ---swiper.js 插件,

然后呢就开始写轮播图了

<div class="swiper-container">--首先定义一个容器
   <div class="swiper-wrapper">
    <div class="swiper-slide"><img src="" /></div> --添加图片
    <div class="swiper-slide"><img src="" /></div>
    <div class="swiper-slide"><img src="" /></div>
   </div>
   <div class="swiper-pagination"></div>--小圆点分页器
   <div class="swiper-button-prev"></div>--上一页
   <div class="swiper-button-next"></div>--下一页
  </div>

如果想让它动起来,那就继续来写js吧

var mySwiper = new Swiper(".swiper-container",{
     autoplay:1000,--每秒中轮播一次
     loop:true,--可以让图片循环轮播
     autoplayDisableOnInteraction:false,--在点击之后可以继续实现轮播
     pagination:".swiper-pagination",--让小圆点显示
     paginationClickable:true,--实现小圆点点击
     prevButton:".swiper-button-prev",--实现上一页的点击
     nextButton:".swiper-button-next",--实现下一页的点击
            effect:"flip"--可以实现3D效果的轮播
    })

Swiper轮播的也有它的好处:

    1.Swiper是纯javascript打造的滑动特效插件,面向手机、平板电脑等移动终端。
    2.Swiper能实现触屏焦点图、触屏Tab切换、触屏多图切换等常用效果。
    3.Swiper开源、免费、稳定、使用简单、功能强大,是架构移动终端网站的重要选择!

同时也有不足之处:(使用Swiper轮播插件ajax请求加载图片时,无法滑动的问题)
因为banner图是动态创建的,在插件开始初始化时,文档流中没用图片,所以没有创建相应宽度,通过调整js加载顺序,问题还是没有解决。
最后找到swiper插件 api 有属性是可以根据内容变动,自动初始化插件的,添加observer:true后问题解决!

var mySwiper = new Swiper ('.swiper-container', {
pagination: '.swiper-pagination',
autoplay: 5000,
loop: true,
observer:true,//修改swiper自己或子元素时,自动初始化swiper
observeParents:true,//修改swiper的父元素时,自动初始化swiper
}) 

Swiper拥有丰富的API接口。(不过关于中文文档不多,没找着。)能够让开发者生成个人独有的分页器(pagination),上下滑块的按钮

以及4个回调函数:1.onTouchStart
         2.onTouchMove
         3.onTouchEnd
         4.onSlideSwitch。
以上内容是我个人总结,希望对各位有所帮助!

swiper轮播图(逆向自动切换类似于无限循环)

swiper插件轮播图,默认的轮播循序是会从右向左,第一张,第二张,第三张,然后肉眼可见是的从第三张从左到右倒回第一张,这样就会有些视觉体验不高,

,不过还是能够用swiper本身的特性更改成无限循环的轮播的。

HTML代码

<div class="course-banner-box">
  <div class="swiper-container">
    <div class="swiper-wrapper"> <!--四张轮播图-->
      <div class="swiper-slide slide1"></div>
      <div class="swiper-slide slide2"></div>
      <div class="swiper-slide slide3"></div>
      <div class="swiper-slide slide4"></div>
    </div>
    <!-- Add Pagination -->
    <div class="swiper-pagination"></div>
    <!-- Add Arrows -->
    <div class="button-box">
      <div class="button"> <!--左右按钮-->
        <div class="swiper-button-next"></div>
        <div class="swiper-button-prev"></div>
      </div>

    </div>

  </div>
</div>

script代码

<script>
  var swiper = new Swiper('.swiper-container', {
    pagination: '.swiper-pagination',//pagination分页器
    nextButton: '.swiper-button-next',//前进后退按钮
    prevButton: '.swiper-button-prev',
    paginationClickable: true,//参数设置为true时,点击分页器的指示点分页器会控制Swiper切换
    spaceBetween: 30,//slide之间的距离(单位px)。
    centeredSlides: true,//设定为true时,活动块会居中,而不是默认状态下的居左。
    loop : true,//复制多份循环(这里就是让轮播看起来是循环的,去掉这个就恢复了默认的swiper轮播)
    autoplay: 3000,//自动切换的时间间隔(单位ms),不设定该参数slide不会自动切换。
    autoplayDisableOnInteraction: false//点击后打断auto-play
  });
</script>

以上就是swiper 自动图片无限轮播的全部内容了,需要的朋友可以可以参考一下。

相关文章

最新评论