对于用 css 实现一个轮播图的缘由,是那时候刚开始接触前端,完全还不懂 js。但是有一个项目(就是一个用来应付面试的作品)需要做一个轮播的效果,当时第一反应就是用 css3 自定义动画 -webkit-animation。做出来的效果自己觉得还可以,唯一的不足就是鼠标点击切换 banner 图和指定到某个图。如果项目中不需要切换变换图片的需求,用 css3 做,何尝不是一种办法。不多说,先上代码:

html 代码如下:

<div class="test">
<a href="#" ><img class="img1" src="1.jpg" ></a>
<a href="#" ><img class='img2' src="2.jpg" ></a>
<a href="#" ><img class='img3' src="3.jpg" ></a>
<a href="#" ><img class='img4' src="4.jpg" ></a>
</div>

接着 css 代码:

@keyframes t1{
0%{ left:; }
20%{ left:; }
25%{ left: -960px; }
45%{ left: -960px; }
50%{ left: -1920px; }
70%{ left: -1920px; }
75%{ left: -2880px; }
95%{ left: -2880px; }
100%{ left:; }
}
@keyframes t2{
0%{ left: 960px; }
20%{ left: 960px; }
25%{ left:; }
45%{ left:; }
50%{ left: -960px; }
70%{ left: -960px; }
75%{ left: -1920px; }
95%{ left: -1920px; }
100%{ left: 960px; }
}
@keyframes t3{
0%{ left: 1920px; }
20%{ left: 1920px; }
25%{ left: 960px; }
45%{ left: 960px; }
50%{ left:; }
70%{ left:; }
75%{ left: -960px; }
95%{ left: -960px; }
100%{ left: 1920px; }
}
@keyframes t4{
0%{ left: 2880px; }
20%{ left: 2880px; }
25%{ left: 1920px; }
45%{ left: 1920px; }
50%{ left: 960px; }
70%{ left: 960px; }
75%{ left:; }
95%{ left:; }
100%{ left: 2880px; }
}

这里定义了 t1、t2、t3、t4 四个动画名称(兼容的写法:自行在 'keyframes' 前加前缀),主要是动画里的帧数的设置技巧,因为只有4张图,所以就取每次帧数增加 25% 的时候才让 left 值减去图片宽度,而在改变 left 值之前的 5%(这个值根据情况调整)处 left 值保持不变,而这个 5% 表示的就是轮播图中图片移动的时间,另外 20% 表示的就是图片禁止的状态。然后把这4个自定义动画一一放到每一个 img 里,例如:

.test .img1{
left:;
-webkit-animation: t1 linear 12s infinite;
-moz-animation: t1 linear 12s infinite;
-ms-animation: t1 linear 12s infinite;
-o-animation: t1 linear 12s infinite;
animation: t1 linear 12s infinite;
}
.test .img2{
left: 960px;
-webkit-animation: t2 linear 12s infinite;
-moz-animation: t2 linear 12s infinite;
-ms-animation: t2 linear 12s infinite;
-o-animation: t2 linear 12s infinite;
animation: t2 linear 12s infinite;
}
.test .img3{
left: 1920px;
-webkit-animation: t3 linear 12s infinite;
-moz-animation: t3 linear 12s infinite;
-ms-animation: t3 linear 12s infinite;
-o-animation: t3 linear 12s infinite;
animation: t3 linear 12s infinite;
}
.test .img4{
left: 2880px;
-webkit-animation: t4 linear 12s infinite;
-moz-animation: t4 linear 12s infinite;
-ms-animation: t4 linear 12s infinite;
-o-animation: t4 linear 12s infinite;
animation: t4 linear 12s infinite;
}
.test:hover img{
-webkit-animation-play-state: paused;
-moz-animation-play-state: paused;
-ms-animation-play-state: paused;
-o-animation-play-state: paused;
animation-play-state: paused;
}

代码最后给了一个鼠标移上去,动画停止的效果,整个轮播的时间自行设置,‘infinite’ 表示一直持续轮播。

ps:这个是一个正序的轮播,同理也可以实现正反序轮播,在定义动画那里改改帧数设置就行,有疑问,欢迎在评论中提出,谢谢大家。

用 CSS 做轮播图的更多相关文章

  1. 用js和jQuery做轮播图

    Javascript或jQuery做轮播图 css样式 <style> a{ text-decoration:none; } .naver{ width: 100%; position:r ...

  2. 基于css制作轮播图的部分效果

    在轮播图中,我们可以通过鼠标在特定位置上的滑动来实现元素背景的改变.通常在制作轮播图时,我们首先想到的是js中的交互.可是,如果我们无法使用js,只能单纯的靠css又该如何实现这一效果呢?下面,本人将 ...

  3. jQuery做轮播图

    这是我自己做的一个简单的轮播图,效果图如下: 我觉得轮播图中最主要的是要理解到图片为什么会滑动,是怎么控制的.上面这个我自己做的,是搭好的一个结构,在无序列表中插入需要的图片.然后在插入图片的后面添加 ...

  4. React Native 如何做轮播图 react-native-swiper

    //:仿饿了么github:https://github.com/stoneWeb/elm-react-native 欢迎各位同学加入: React-Native群:397885169 大前端群:54 ...

  5. 纯CSS实现轮播图效果,你不知道的CSS3黑科技

    前言 轮播图已经是一个很常见的东西,尤其是在各大App的首页顶部栏,经常会轮番显示不同的图片. 一提到轮播图如何实现时,很多人的第一反应就是使用Javascript的定时器,当然这种方法是可以实现的. ...

  6. 拓展-教你手把手用纯CSS写轮播图

    先看成品图[示例网址:][1] [1]: https://huruji.github.io/css-imitate-js/slider/index.html一.随便说几句####css3动画效果的强大 ...

  7. 用avalon框架怎么做轮播图?

    avalon这个框架其实特别的小众,做个轮播图呢?在github上的例子只有一个,而且功能特别的少,有的引入的插件与avalon里面的指令又不兼容,所以找了一个owl-carousel,目前实现了移动 ...

  8. 使用css实现轮播图

    使用css3实现图片轮播 前言:实现图片轮播的方式有很多种 ,例如js ,css 等等. 本文主要讲述使用纯css3实现轮播图 工具介绍: 使用的编辑器: Hbuilder 进入正题 html代码: ...

  9. 使用css制作轮播图

    <!--HTML代码--> <!DOCTYPE html> <html lang="en"><head> <meta char ...

随机推荐

  1. 什么是blob,mysql blob大小配置介绍

    什么是blob,mysql blob大小配置介绍 作者: 字体:[增加 减小] 类型:转载   BLOB (binary large object),二进制大对象,是一个可以存储二进制文件的容器.在计 ...

  2. MYSQL导入导出.sql文件

    MYSQL导入导出.sql文件   一.MYSQL的命令行模式的设置:桌面->我的电脑->属性->环境变量->新建->PATH=“:path\mysql\bin;”其中p ...

  3. SpringMVC 基于注解的Controller详解

    本文出处 http://blog.csdn.net/lufeng20/article/details/7598801 概述 继 Spring 2.0 对 Spring MVC 进行重大升级后,Spri ...

  4. 【php学习】时间函数

    手工画了一张图,来大体概括php中对于时间的处理函数 首先时间戳是这样“1441202665”的一串数字,虽然人看起来麻烦,但是计算机却很容易识别这样的时间表示形式. 所以给计算机看的时间是时间戳,给 ...

  5. 策略模式代替大量的if else

    原代码 public class Example { public Double calRecharge(Double charge, RechargeTypeEnum type) { if (typ ...

  6. BLE GATT规范中关于UUID与属性的详细解析

    1. 角色 除了GAP定义了角色之外,BLE还定义了另外2种角色:GATT服务器和GATT客户端,它们完全独立于GAP的角色.提供数据的设备称为GATT服务器,访问GATT服务器而获得数据的设备称为G ...

  7. 关于cocoa框架,你所要知道的一切(苹果官方文档,cocoa框架核心竞争力,必须收藏!)

    https://developer.apple.com/library/ios/documentation/General/Conceptual/DevPedia-CocoaCore/Accessib ...

  8. Activity初步,初学者必看

    Activity是什么? Activity是一个可与用户交互并呈现组件的视图.通俗说就是运行的程序当前的这个显示界面. 如果你还不明白,那么你写过HTML吗,它就好比一个网页.我们程序中的用户视图,都 ...

  9. Qt Focus事件,FocusInEvent()与FocusOutEvent()

    描述:一开始我要实现的目的就是,在一个窗体上有多个可编辑控件(比如QLineEdit.QTextEdit等),当哪个控件获得焦点,哪个控件的背景就高亮用来起提示作用,查了下文档应该用focusInEv ...

  10. Solr4+IKAnalyzer的安装配置

    一.下载Solr4.10.2 我们以Windows版本为例,solr-4.10.2.zip是目前最新版本,下载地址: http://www.apache.org/dyn/closer.cgi/luce ...