---恢复内容开始---

大家还记得我昨天的3D拖拽立方体吗??我昨天还说过css还可以做轮播图,所以咱们今天就写一下,css的轮播图吧!

....这个轮播图主要是用CSS3里的transform的旋转属性来完成3D效果的,然后配合原生js的显示隐藏,达到了3D旋转轮播图的效果:

<!DOCTYPE HTML>
<html> <head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>3D图片切换1</title>
<style>
/*设置一个关键帧*/
@-webkit-keyframes open {
0% {
-webkit-transform: rotateX(180deg);
opacity: 0;
}
57% {
-webkit-transform: rotateX(-16deg);
opacity: 1;
}
66% {
-webkit-transform: rotateX(14deg);
}
74% {
-webkit-transform: rotateX(-12deg);
}
81% {
-webkit-transform: rotateX(10deg);
}
87% {
-webkit-transform: rotateX(-8deg);
}
92% {
-webkit-transform: rotateX(6deg);
}
96% {
-webkit-transform: rotateX(-4deg);
}
100% {
-webkit-transform: rotateX(0deg);
}
} @-webkit-keyframes clos {
0% {
-webkit-transform: rotateX(0deg);
opacity: 1;
}
100% {
-webkit-transform: rotateX(-180deg);
opacity: 0;
}
} body {
background: #eee;
} .box {
width: 600px;
height: 400px;
position: relative;
margin: 30px auto;
} /*按钮*/ #prev,
#next {
width: 50px;
height: 50px;
background: #efefef;
border-radius: 25px;
position: absolute;
top: 100px;
box-shadow: 2px 2px 10px #666;
text-align: center;
font-size: 40px;
line-height: 50px;
font-family: Verdana, Geneva, sans-serif;
text-decoration: none;
color: #fff;
-webkit-text-stroke: 2px #ccc;
} #prev {
left: -100px;
} #next {
right: -100px;
}
/*图片区*/
#imgs {
width: 600px;
height: 400px;
position: relative;
-webkit-transform-style: preserve-3d;
-webkit-perspective: 1000px;
}
/*图片*/
#imgs img {
width: 600px;
height: 400px;
position: absolute;
left: 0;
top: 0;
-webkit-transform-origin: bottom;
-webkit-transform: rotateX(-180deg);
opacity: 0;
}
/*设置显示和隐藏后的样式*/
#imgs .show {
-webkit-animation: open 1.2s ease-in;
-webkit-transform: rotateX(0deg);
opacity: 1;
} #imgs .hide {
-webkit-animation: clos 1s ease;
-webkit-transform: rotateX(-180deg);
opacity: 0;
}
</style>
<script> window.onload = function() {
//要用到的元素获取元素
var oPrev = document.getElementById("prev");
var oNext = document.getElementById("next");
var aImg = document.getElementsByTagName("img");
var iNow = 0;
//上一页点击事件
oPrev.onclick = function() { aImg[iNow].className = "hide";
iNow--;
if(iNow < 0) {
//判断全局变量
iNow = aImg.length - 1;
}
aImg[iNow].className = "show";
};
//下一页点击事件
oNext.onclick = function() {
aImg[iNow].className = "hide";
iNow++;
if(iNow == aImg.length) {
// 如果全局变量和长度相等,就变回第一张,造成视觉循环的假象
iNow = 0;
}
aImg[iNow].className = "show";
};
}
</script>
</head> <body>
<div class="box">
<!--上一页-->
<a href="#" id="prev"><</a>
<div id="imgs">
<img src="img/img1.jpg" alt="" class="show" />
<img src="img/img2.jpg" alt="" />
<img src="img/img3.jpg" alt="" />
<img src="img/img4.jpg" alt="" />
<img src="img/img5.jpg" alt="" />
</div>
<!--下一页-->
<a href="#" id="next">></a>
</div>
</body>
</html>

  不知道你们学会了吗???很简单哦!

---恢复内容结束---

CSS3,3D效果轮播图的更多相关文章

  1. css3实现3D切割轮播图案例

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  2. 案例:3D切割轮播图

    一.3d转换 3D旋转套路:顺着轴的正方向看,顺时针旋转是负角度,逆时针旋转是正角度 二.代码 <!DOCTYPE html> <html lang="en"&g ...

  3. 带锁的3D切割轮播图

    3D切割轮播图. 加入锁,限制点击太快次数 <!DOCTYPE html><html><head lang="en"> <meta cha ...

  4. 【前端】javascript+jQuery实现旋转木马效果轮播图slider

    实现效果: 实现原理: 技术栈: javascript+jQuery+html+css 实现步骤: // 0. 获取元素 // 1. 鼠标放置到轮播图上,显示两侧的控制按钮,移开后隐藏 // 2. 为 ...

  5. js访3d上下轮播图

    js/css访3d上下轮播图 (附件) <!DOCTYPE html> <html> <head> <meta charset="utf-8&quo ...

  6. 使用Swiper快速实现3D效果轮播

    最近经常接到轮播图3D效果的需求, 特在此记录一下以备之后使用. 具体实现效果如下: 在这里介绍两种使用方式, 一种原生的html+php后端渲染, 一种是使用vue. 原生实现 引入 首先我们介绍原 ...

  7. CSS3+JS切割轮播图

    以下说明数据,是指有4张图片的轮播图,分别切割成4张. 首先,做成单张切换的立体效果,即通过旋转,确定四张图片的位置,分别是一个立方体的上下前后的图片翻转移动角度. .box ul li:nth-ch ...

  8. jQuery淡入淡出效果轮播图

    用JavaScript做了平滑切换的焦点轮播图之后,用jQuery写了个简单的淡入淡出的轮播图,代码没有做优化,html结构稍微有一些调整,图片部分用ul替换了之前用的div. html结构如下: & ...

  9. CSS3 实现简单轮播图

    用css3动画实现图片切换效果,原理还是改变left值.只有最简单的自动播放功能,切换后短时间静止,通过最后的位置克隆第一张图片,实现无缝切换. html结构 <div id="con ...

随机推荐

  1. css提取数据2个常用方法

    提取标签里的内容 所谓数据就是HTML里标签的内容,如下面红色字体,就是标签内容 <title>我只是个实验 - SCRAPY</title> 提取标签里的数据,标签可以是ti ...

  2. 4G和有线网络的自动切换

    最近项目有个需求,把移动服务器设备(Ubuntu14.04)安装4G模块,但如果连接有线时,可以自动切换到有线,以降低移动流量带来的费用. 以下是我实现的方法(经过一番痛苦的摸索) 1. 脚本/opt ...

  3. 2.使用ngx_http_auth_basic_module模块为不带认证的资源添加授权

    1.首先需要生成用户名和密码 使用openssl来生成,生成命令(openssl在安装nginx的时候已经安装) echo "kibana:$(openssl passwd -crypt y ...

  4. WIndows下 Pycharm 配置Anaconda和TensorFlow

    1安装PyCharm 前提安装Python,然后去官网下载PyCharm 2 安装Anaconda 在官网下载Anaconda,并安装 下载好之后就跟安装一般的软件没啥区别,选择自己安装的文件夹,下一 ...

  5. Cook-Torrance光照模型

    Cook-Torrance光照模型将物体粗糙表面看作由很多微平面组成,每一个微平面都可以看成一个理想的镜面反射体,物体表面粗糙程度由微平面斜率的变化来表示.越粗糙的表面由斜率变化越大,反之越小. Co ...

  6. 安装APK时报 Installation failed with message Failed to finalize session : INSTALL_FAILED_USER_RESTRICTED: Invalid apk.

    Installation failed with message Failed to finalize session : INSTALL_FAILED_USER_RESTRICTED: Invali ...

  7. springboot整合security实现基于url的权限控制

    权限控制基本上是任何一个web项目都要有的,为此spring为我们提供security模块来实现权限控制,网上找了很多资料,但是提供的demo代码都不能完全满足我的需求,因此自己整理了一版. 在上代码 ...

  8. 判断文本(text_to_be_present_in_element)

    判断文本 在做结果判断的时候,经常想判断某个元素中是否存在指定的文本,如登录后判断页面中是账号是否是该用户的用户名.在前面的登录案例中,写了一个简单的方法,但不是公用的,在 EC 模块有个方法是可以专 ...

  9. 【CSS】 元素块与文字的各种居中解决方案

    元素块的居中 首先有这样一个200*200px的元素块在界面内. 元素块的水平居中: 如果想要让其水平居中,则有三种方法: 第一种是知道屏幕的长宽,则根据计算,(屏幕宽X-元素块宽Y)/ 2的结果是元 ...

  10. unity小地图上的动态图标

    unity制作小地图简单,用rawImage 再来个摄像机就行 但是现在一个需求就是地图上一些东西要加上图标,图标会随着地图物体的移动而移动 然后去网上下载了个小地图插件  UGUI MiniMap( ...