css3轮播案例(纯CSS3实现图片无间断轮播效果)
类别:Web前端 浏览量:2002
时间:2022-01-20 00:51:05 css3轮播案例
纯CSS3实现图片无间断轮播效果前言:图片轮播效果现在在各大网站都是非常普遍的,以前我们都是通过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:
- <!DOCTYPE html>
- <html>
- <head lang="en">
- <meta charset="UTF-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
- <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=0,minimal-ui">
- <meta content="yes" name="apple-mobile-web-app-capable" />
- <meta content="black" name="apple-mobile-web-app-status-bar-style" />
- <meta content="telephone=no" name="format-detection" />
- <title>轮播DEMO | 科博网-钟科的个人博客</title>
- <style>
- *{ padding:0; margin:0; border:0; }
- .wrap{ position: relative; height: 500px; width:360px; overflow:hidden; border:1px solid #ccc; margin:10px auto; }
- .wrap-list{ width:9999px; transform:translate3d(-360px,0,0); transition-delay: .3s; transition:ease; }
- .wrap-list img{ float:left; width:360px; height: 500px; }
- .btns{ text-align:center; }
- .btns button{ width:100px; height: 30px; }
- </style>
- </head>
- <body>
- <li class="wrap">
- <li class="wrap-list">
- <!--这里需要clone-->
- <img src="http://img.mrco.cn/PKUgbaXooTzIz4TZQl7heAGF.jpg" alt="css3轮播案例(纯CSS3实现图片无间断轮播效果)" border="0" />>
- <img src="http://img.mrco.cn/VQeqlUbGMLcGqpy-QnDjzyZn.jpg" alt="css3轮播案例(纯CSS3实现图片无间断轮播效果)" border="0" />>
- <img src="http://img.mrco.cn/E32rcqdZn0uMt9JbXr0w0K95.jpg" alt="css3轮播案例(纯CSS3实现图片无间断轮播效果)" border="0" />>
- <img src="http://img.mrco.cn/uWHhrhu.jpg" alt="css3轮播案例(纯CSS3实现图片无间断轮播效果)" border="0" />>
- <img src="http://img.mrco.cn/k2wZVNRo0YNU7i-wuC_-84Du.jpg" alt="css3轮播案例(纯CSS3实现图片无间断轮播效果)" border="0" />>
- <img src="http://img.mrco.cn/PKUgbaXooTzIz4TZQl7heAGF.jpg" alt="css3轮播案例(纯CSS3实现图片无间断轮播效果)" border="0" />>
- <!--这里需要clone-->
- <img src="http://img.mrco.cn/VQeqlUbGMLcGqpy-QnDjzyZn.jpg" alt="css3轮播案例(纯CSS3实现图片无间断轮播效果)" border="0" />>
- </li>
- </li>
- <li class="btns">
- <button id="btnLeft">左</button>
- <button id="btnRight">右</button>
- </li>
- <script src="http://s.mrco.cn/scripts/libs/zepto/zepto.min.js?0.0.1"></script>
- <script src="http://s.mrco.cn/scripts/libs/zepto/selector.js?0.0.1"></script>
- <script src="http://s.mrco.cn/scripts//libs/zepto/touch.js?0.0.1"></script>
- </body>
- </html>
JavaScript:
- $(function(){
- var index = 1, //默认的当前索引为1,因为clone了最有一个dom在第一个前面做衔接
- moveWidth = 360; //每次需要移动的像素值
- //左移动
- $('#btnLeft').on('click',function(){
- //每次+1
- index++;
- //通过索引乘以移动像素值,那么就得到了移动的步位
- $('.wrap-list').css({ transform:'translate3d(-'+ (index * moveWidth) +'px,0,0);transition-duration: 0.3s;' });
- //这里的判断是衔接的关键所在,如果当前索引已经是最后一个dom了,也就是我们clone好的这个dom了,那就说明已经需要开始重新开始新的一轮了
- if(index == $('.wrap-list img').size() - 1){
- //css3的动画有一个300毫秒的执行时间,所以我们这里也需要等待300毫秒后再进行重置操作
- setTimeout(function () {
- //重置索引为1,相当于重头开始
- index = 1;
- //重置wrap盒子为默认的其实位置开始,这里的css3的效果被去除了,所以看不出来有移动的效果,我们注意看transition-duration:0s;
- $('.wrap-list').css({transform: 'translate3d(-' + (index * moveWidth) + 'px,0,0);transition-duration: 0s;'})
- }, 300);
- }
- });
- //右移动
- $('#btnRight').on('click',function(){
- //每次减一
- index--;
- //通过索引乘以移动像素值,那么就得到了移动的步位
- $('.wrap-list').css({ transform:'translate3d(-'+ (index * moveWidth) +'px,0,0);transition-duration: 0.3s;' });
- //这里的判断是衔接的关键所在,跟向右移是一个意思,等于0的时候就是到了clone的dom了,也就需要重新开始新的一轮了
- if(index === 0) {
- //css3的动画有一个300毫秒的执行时间,所以我们这里也需要等待300毫秒后再进行重置操作
- setTimeout(function () {
- //这里就需要设置到除去两个clone的dom之外的最后一个dom索引来
- index = $('.wrap-list img').size() - 2;
- //重置wrap盒子为默认的其实位置开始,这里的css3的效果被去除了,所以看不出来有移动的效果,我们注意看transition-duration:0s;
- $('.wrap-list').css({transform: 'translate3d(-' + (index * moveWidth) + 'px,0,0);transition-duration: 0s;'})
- }, 300);
- }
- });
- });
以上所述是小编给大家介绍的纯CSS3实现图片无间断轮播效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对开心学习网网站的支持!
您可能感兴趣
- jquery图片轮播代码
- dede友情链接改为logo轮播教程(dedecms广告生成JS文件和JS调用-DEDE广告优化)
- html5自动轮播图代码(HTML5播放实现rtmp流直播)
- jquery轮播图的左右按钮(jQuery轮播图功能实现方法)
- vue组件轮播(vue+rem自定义轮播图效果)
- dede友情链接改为logo轮播教程(织梦dede调用四级栏目的实现方法)
- js轮播图片(JS实现简单图片轮播效果)
- 前端轮播图效果(AmazeUI图片轮播效果的示例代码)
- js实现自动轮播(原生js封装无缝轮播功能)
- javascript中图片轮播效果代码(JavaScript实现简单的轮播图效果)
- 如何设置bootstrap轮播图的速度(bootstrap实现轮播图效果)
- dedecms设置轮播图(织梦dedecms网站地图改变生成目录的方法)
- css3轮播案例(纯CSS3实现图片无间断轮播效果)
- vue轮播图代码(vue实现无缝轮播效果跑马灯)
- jquerycss3轮播案例(CSS3实现列表无限滚动/轮播效果)
- 原生js实现轮播图代码(js实现轮播图制作方法)
- 你知道 七夕 的真正含义吗(你知道七夕的真正含义吗)
- 七夕的寓意(七夕的寓意)
- 苏志燮赵恩静结婚,韩国四大公共财产变三人,这么快就有替补了(苏志燮赵恩静结婚)
- 《内在美》后,一大波新韩剧来袭,李钟硕朴信惠宋慧乔玄彬回归(一大波新韩剧来袭)
- 给孩子选购保温杯,注意这4个步骤,比颜值更重要(给孩子选购保温杯)
- 保温好 容量大 颜值高 保温杯你给娃娃买对了吗(保温好容量大颜值高)
热门推荐
- 如何在windows上搭建ftp服务器(Windows Server 2016如何搭建部署FTP服务器)
- python抽奖转盘代码(详解python--模拟轮盘抽奖游戏)
- mysqlpxc性能(MySQL之PXC集群搭建的方法步骤)
- css渐变有几种(CSS 还能这样玩?奇思妙想渐变的艺术)
- php中命名空间常用吗(PHP命名空间定义与用法实例分析)
- nginx和lua哪个好(nginx+lua单机上万并发的实现)
- dede栏目下有内容却不显示(dedecms列表不显示第一个元素如分隔符的简单方法)
- linux系统的组成架构(Linux输入子系统框架原理解析)
- mysql8.0.16安装步骤图解(mysql 8.0.22 安装配置图文教程)
- python2.7连接sqlserver数据库(Python使用sqlalchemy模块连接数据库操作示例)