栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

纯CSS3实现图片无间断轮播效果

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

前言:图片轮播效果现在在各大网站都是非常普遍的,以前我们都是通过postion的left or right来控制dom的移动,这里我要说的是利用css3来制作轮播!相比以前通过postion来移动dom来说,css3的实现方式更为优雅!

我相信使用过css3的童鞋们应该都知道我们是用css哪个大哥属性了吧!嗯,对的,就是translate3d我在前几天还特地写过一篇文章来介绍它,不熟悉的童鞋可以点击关键字链接过去看看!知道的童鞋们,那我们继续往下看!

效果图如下所示:



首先,我们先说下思路

非无限循环: 直接设置每次移动的位移数值,然后根据时间段执行,比如索引从0-10,直接判断是否到0了,最后是否到10了,然后到了0或者10的时候直接将索引设置我相反的索引数就可以了。

无限循环: 无限循环的就需要考虑前后的衔接了,比如第一张图跟最后一张图,在执行的最后一张图的时候应该会出现第一张图,那么相反之下出现第一张图然后往右翻的时候就应该出现最后一张图。那么这是这么做到的呢?其实很简单,那就是clone克隆最后一个dom到第一个dom的前面,然后clone第一个dom到最后一个dom的后面,可能我这么说,大家听起来有点晕。那么我们直接看看下面的代码就知道原理了!

HTML:

XML/HTML Code复制内容到剪贴板
  1.   
  2.   
  3.   
  4.       
  5.       
  6.       
  7.       
  8.       
  9.       
  10.     轮播DEMO | 科博网-钟科的个人博客  
  11.       
  12.   
  13.   
  14.   
  15.       
  16.           
  17.         

      
  18.         

      
  19.         

      
  20.         

      
  21.         

      
  22.         

      
  23.           
  24.         

      
  25.     
  
  •   
  •   
  •     左  
  •     右  
  •   
  •   
  •   
  •   
  •   
  •   
  • Javascript:

    Javascript Code复制内容到剪贴板
    1. $(function(){   
    2.         var index = 1,          //默认的当前索引为1,因为clone了最有一个dom在第一个前面做衔接   
    3.             moveWidth = 360;    //每次需要移动的像素值   
    4.         //左移动   
    5.         $('#btnLeft').on('click',function(){   
    6.             //每次+1   
    7.             index++;   
    8.             //通过索引乘以移动像素值,那么就得到了移动的步位   
    9.             $('.wrap-list').css({ transform:'translate3d(-'+ (index * moveWidth) +'px,0,0);transition-duration: 0.3s;' });   
    10.             //这里的判断是衔接的关键所在,如果当前索引已经是最后一个dom了,也就是我们clone好的这个dom了,那就说明已经需要开始重新开始新的一轮了   
    11.             if(index == $('.wrap-list img').size() - 1){   
    12.                 //css3的动画有一个300毫秒的执行时间,所以我们这里也需要等待300毫秒后再进行重置操作   
    13.                 setTimeout(function () {   
    14.                     //重置索引为1,相当于重头开始   
    15.                     index = 1;   
    16.                     //重置wrap盒子为默认的其实位置开始,这里的css3的效果被去除了,所以看不出来有移动的效果,我们注意看transition-duration:0s;   
    17.                     $('.wrap-list').css({transform: 'translate3d(-' + (index * moveWidth) + 'px,0,0);transition-duration: 0s;'})   
    18.                 }, 300);   
    19.             }   
    20.         });   
    21.         //右移动   
    22.         $('#btnRight').on('click',function(){   
    23.             //每次减一   
    24.             index--;   
    25.             //通过索引乘以移动像素值,那么就得到了移动的步位   
    26.             $('.wrap-list').css({ transform:'translate3d(-'+ (index * moveWidth) +'px,0,0);transition-duration: 0.3s;' });   
    27.             //这里的判断是衔接的关键所在,跟向右移是一个意思,等于0的时候就是到了clone的dom了,也就需要重新开始新的一轮了   
    28.             if(index === 0) {   
    29.                 //css3的动画有一个300毫秒的执行时间,所以我们这里也需要等待300毫秒后再进行重置操作   
    30.                 setTimeout(function () {   
    31.                     //这里就需要设置到除去两个clone的dom之外的最后一个dom索引来   
    32.                     index = $('.wrap-list img').size() - 2;   
    33.                     //重置wrap盒子为默认的其实位置开始,这里的css3的效果被去除了,所以看不出来有移动的效果,我们注意看transition-duration:0s;   
    34.                     $('.wrap-list').css({transform: 'translate3d(-' + (index * moveWidth) + 'px,0,0);transition-duration: 0s;'})   
    35.                 }, 300);   
    36.             }   
    37.         });   
    38.     });  

    以上所述是小编给大家介绍的纯CSS3实现图片无间断轮播效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对考高分网网站的支持!

    转载请注明:文章转载自 www.mshxw.com
    本文地址:https://www.mshxw.com/it/217720.html

    CSS教程相关栏目本月热门文章

    我们一直用心在做
    关于我们 文章归档 网站地图 联系我们

    版权所有 (c)2021-2022 MSHXW.COM

    ICP备案号:晋ICP备2021003244-6号