网络编程
位置:首页>> 网络编程>> JavaScript>> swiper 自动图片无限轮播实现代码

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

作者:mdxy-dxy  发布时间:2024-06-09 17:26:12 

标签:图片,无限轮播

完整代码


<!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>
0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com