CSS3+JavaScript实现翻页幻灯片效果


Posted in Javascript onJune 28, 2017

先上效果图

CSS3+JavaScript实现翻页幻灯片效果

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
      *{
        margin: 0;
        padding: 0;
      }
      #content{
        width: 500px;
        height: 300px;
        margin: 40px auto;
        position: relative;
        transform-style: preserve-3d;
      }
      #content>div{
        width: 100%;
        height: 100%;
        position: absolute;
        transform-origin: center bottom;
      }
      #content img{
        width: 100%;
        height: 100%;
      }
      #next{
        position: absolute;
        top:190px;
        left: calc(33% - 60px);
      }
      #prev{
        position: absolute;
        top: 190px;
        left: calc(68% + 30px);
      }
      @keyframes next{  //创建一个动画这是一个翻到下面的效果
        from{
          -wbelit-transform: perspective(1000px) rotateX(0deg); /* 开始位置是 0°*/
          opacity: 1; //初始透明为1
        }
        to{
          -webkit-transform: perspective(1000px) rotateX(-180deg); /*结束位置是 180°*/
          opacity: 0; //结束透明为0
        }
      }
      @keyframes prev{ //创建一个由上边翻到上边的动画
        0%{
          -webkit-transform: perspective(1000px) rotateX(180deg); /* 初始开始位置 */
          opacity:0;    //初始为透明
        }
        57%
        {
          -webkit-transform: perspective(1000px) rotateX(-16deg); /* 动画进行到 56% 的时候他为 -16° */
          opacity:1; //透明已经为1 了
        }
        66%
        {
          -webkit-transform: perspective(1000px) rotateX(14deg); /* 再回到 14° 的位置 */
        }
        74%
        {
          -webkit-transform: perspective(1000px) rotateX(-12deg); /* 再回到 -12°的位置 */
        }
        81%
        {
          -webkit-transform: perspective(1000px) rotateX(10deg); /* 再回到 10°的位置 */
        }
        87%
        {
          -webkit-transform: perspective(1000px) rotateX(-8deg); /* 再回到 -8°的位置 */
        }
        92%
        {
          -webkit-transform: perspective(1000px) rotateX(6deg); /* 再回到 6° 的位置 */
        }
        96%
        {
          -webkit-transform: perspective(1000px) rotateX(-4deg); /* 再回到 -4° 的位置 */
        }
        100%
        {
          -webkit-transform: perspective(1000px) rotateX(0deg); /* 最后回归 0° */
        }<br>



















      }
      .next{
        animation: next 1s ease 1 normal 0s; /* 执行向下的动画 */
        transform: rotateX(-180deg); /* 因为初始位置是0 但当你执行完动画还会回到原位 所以它转到哪里就把他设在哪里不要再让它回去了 */
        opacity: 0;
      }
      .prev{
        animation: prev 1.2s ease 1 normal 0s; /* 执行向上的动画 */
        transform: rotateX(0deg); /* 同上 */
        opacity: 1;
      }
    </style>
  </head>
  <body>
    <button id="next">←</button><button id="prev">→</button>
    <div id="content">
      <div class="prev"><img src="images/012.jpeg"></div> <!-- 设置默认的第一页 -->
      <div class="next"><img src="images/017.jpeg"></div>
      <div class="next"><img src="images/020.jpeg"></div>
      <div class="next"><img src="images/027.jpeg"></div>
      <div class="next"><img src="images/0df3d7ca7bcb0a46ce09bc1e6e63f6246b60afe9.jpg"></div>
    </div>
    <script>
      window.onload=function(){
        var next=document.getElementById("next");
        var prev=document.getElementById("prev");
        var content=document.getElementById("content");
        var oDiv=content.getElementsByTagName("div");
        var x=0;
        next.onclick=function(){  //当向下翻页时
          oDiv[x].setAttribute("class","next"); //第一个页 设置class名让他向下走去
          x++
          if(x>oDiv.length-1){
            x=0
          }
          oDiv[x].setAttribute("class","prev"); //++过后让他的下一个页面起来
        }
        prev.onclick=function(){    //同上只是++变--
          oDiv[x].setAttribute("class","next");
          x--
          if(x<0){
            x=oDiv.length-1
          }
          oDiv[x].setAttribute("class","prev");
        }
      }
    </script>
  </body>
</html>

以上所述是小编给大家介绍的CSS3+JavaScript实现翻页幻灯片效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
使用prototype.js 的时候应该特别注意的几个问题.
Apr 12 Javascript
javascript 文章截取部分无损html显示实现代码
May 04 Javascript
js函数与php函数的区别实例浅析
Jan 12 Javascript
JavaScript中eval()函数用法详解
Dec 14 Javascript
JavaScript+CSS实现的可折叠二级菜单实例
Feb 29 Javascript
js添加事件的通用方法推荐
May 15 Javascript
jquery.validate表单验证插件使用方法解析
Nov 07 Javascript
node.js+jQuery实现用户登录注册AJAX交互
Apr 28 jQuery
jquery+css3实现熊猫tv导航代码分享
Feb 12 jQuery
JS 使用 window对象的print方法实现分页打印功能
May 16 Javascript
vue使用better-scroll实现下拉刷新、上拉加载
Nov 23 Javascript
使用gulp构建前端自动化的方法示例
Dec 25 Javascript
Node.js 8 中的重要新特性
Jun 28 #Javascript
Angular排序实例详解
Jun 28 #Javascript
基于JS对象创建常用方式及原理分析
Jun 28 #Javascript
Node.js实现文件上传的示例
Jun 28 #Javascript
iscroll-probe实现下拉刷新和下拉加载效果
Jun 28 #Javascript
JavaScript 获取元素在父节点中的下标(推荐)
Jun 28 #Javascript
JS中把函数作为另一函数的参数传递方法(总结)
Jun 28 #Javascript
You might like
php数组转换js数组操作及json_encode的用法详解
2013/10/26 PHP
destoon二次开发常用数据库操作
2014/06/21 PHP
php array_map使用自定义的函数处理数组中的每个值
2016/10/26 PHP
yii框架结合charjs统计上一年与当前年数据的方法示例
2020/04/04 PHP
理解JavaScript中的事件
2006/09/23 Javascript
jQuery实现的多级下拉菜单效果代码
2015/08/24 Javascript
基于JS实现省市联动效果代码分享
2016/06/06 Javascript
基于js对象,操作属性、方法详解
2016/08/11 Javascript
es6学习笔记之Async函数的使用示例
2017/05/11 Javascript
浅谈对Angular中的生命周期钩子的理解
2017/07/31 Javascript
微信小程序显示下拉列表功能【附源码下载】
2017/12/12 Javascript
解决Js先触发失去焦点事件再执行点击事件的问题
2018/08/30 Javascript
微信小程序实现发送验证码按钮效果
2018/12/20 Javascript
JS+HTML5本地存储Localstorage实现注册登录及验证功能示例
2020/02/10 Javascript
详解Vue中的watch和computed
2020/11/09 Javascript
详解React路由传参方法汇总记录
2020/11/29 Javascript
Vue基本指令实例图文讲解
2021/02/25 Vue.js
Python功能键的读取方法
2015/05/28 Python
python3 拼接字符串的7种方法
2018/09/12 Python
详解Python给照片换底色(蓝底换红底)
2019/03/22 Python
Python3.6中Twisted模块安装的问题与解决
2019/04/15 Python
Python解析json时提示“string indices must be integers”问题解决方法
2019/07/31 Python
django重新生成数据库中的某张表方法
2019/08/28 Python
python如何实现单链表的反转
2020/02/10 Python
基于python检查SSL证书到期情况代码实例
2020/04/04 Python
Pycharm Available Package无法显示/安装包的问题Error Loading Package List解决
2020/09/18 Python
安装并免费使用Pycharm专业版(学生/教师)
2020/09/24 Python
美国半成品食材配送服务商:Home Chef
2018/01/25 全球购物
美国领先的家庭健康检测试剂盒提供商:LetsGetChecked
2019/03/18 全球购物
美国折扣地毯销售网站:Rugs.com
2020/03/27 全球购物
2014升学宴答谢词
2014/01/26 职场文书
《十六年前的回忆》教学反思
2014/02/14 职场文书
保送生自荐信
2015/03/06 职场文书
幼儿园小班工作总结2015
2015/04/25 职场文书
浅谈Python数学建模之线性规划
2021/06/23 Python
小喇叭开始广播了! 四十多年前珍贵老照片
2022/05/09 无线电