<!DOCTYPE html>
<html>
 <head>
  <title>css3动画使用技巧之—JQ配合css3实现轮播之animation-delay应用</title>
  <meta charset="utf-8" />
 <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
  <script type="text/javascript">
  $(function(){
var rel=0
      $(".num").each(function(i){
          $(this).click(function(){
              rel=$(this).attr("rel")-1

              $(this).css("background","#ccc").siblings().css("background","red");
              $(".play").css("animation","none").animate({
                  'margin-left':'-300'*rel+'px'
              },500)

              setTimeout(dq,10)
          })

      })

      function dq(){

          $(".play").css({
              'animation-name': 'ma',
            'animation-duration': '10s',
            'animation-timing-function': 'ease-out',
            'animation-delay': '-10'+2*rel+'s',
            'animation-iteration-count':'infinite',
            'animation-direction': 'alternate',
          })
      }

 })

  </script>
    <meta name="author" content="R.tian @eduppp.cn 2015">
    <link rel="shortcut icon"  href="http://eduppp.cn/images/logo4.gif" />
    <link rel="apple-touch-icon" href="http://eduppp.cn/images/logo.gif" />
  <style type="text/css">
        #frame {/*----------图片轮播相框容器----------*/
            position: absolute; /*--绝对定位,方便子元素的定位*/
            width: 300px;
            height: 200px;
            overflow: hidden;/*--相框作用,只显示一个图片---*/
            border-radius:5px;
        }
        #dis {/*--绝对定位方便li图片简介的自动分布定位---*/
            position: absolute;
            left: -50px;
            top: -10px;
            opacity: 0.5;
        }
        #dis li {
            display: inline-block;
            width: 200px;
            height: 20px;
            margin: 0 50px;
            float: left;
            text-align: center;
            color: #fff;
            border-radius: 10px;
            background: #000;
        }
        #photos img {
            float: left;
            width:300px;
            height:200px;
        }
        #photos {/*---设置总的图片宽度--通过位移来达到轮播效果----*/
            position: absolute;z-index:9px;
            width: calc(300px * 5);/*---修改图片数量的话需要修改下面的动画参数*/
        }
        .play{
            animation: ma 10s ease-out infinite alternate;/**/
        }
        @keyframes ma {/*---每图片切换有两个阶段:位移切换和静置。中间的效果可以任意定制----*/
            0%,20% {        margin-left: 0px;        }
            25%,40% {        margin-left: -300px;    }
            45%,60% {        margin-left: -600px;    }
            65%,80% {        margin-left: -900px;    }
            85%,100% {        margin-left: -1200px;    }
        }
        .num{
            position:absolute;z-index:10;
            display:inline-block;
            right:10px;top:165px;
            border-radius:100%;
            background:#f00;
            width:25px;height:25px;
            line-height:25px;
            cursor:pointer;
            color:#fff;
            text-align:center;
            opacity:0.8;
        }
        .num:nth-child(2){margin-right:30px}
        .num:nth-child(3){margin-right:60px}
        .num:nth-child(4){margin-right:90px}
        .num:nth-child(5){margin-right:120px}

  </style>
 </head>
 <body>
 <div id="frame" >
        <a id="a1" class="num" rel="1">1</a>
        <a id="a2" class="num" rel="2">2</a>
        <a id="a3" class="num" rel="3">3</a>
        <a id="a4" class="num" rel="4">4</a>
        <a id="a5" class="num" rel="5">5</a>
        <div id="photos" class="play">
              <img src="http://eduppp.cn/images/0/1.jpg" >
              <img src="http://eduppp.cn/images/0/3.jpg" >
              <img src="http://eduppp.cn/images/0/4.jpg" >
              <img src="http://eduppp.cn/images/0/5.jpg" >
              <img src="http://eduppp.cn/images/0/2.jpg" >
              <ul id="dis">
                <li>中国标志性建筑:天安门</li>
                <li>中国标志性建筑:东方明珠</li>
                <li>中国标志性建筑:布达拉宫</li>
                <li>中国标志性建筑:长城</li>
                <li>中国标志性建筑:天坛</li>
              </ul>
        </div>
</div>
</body>
</html>

请使用高版本狐火打开,没写兼容。

animation-delay为负值时 动画状态是浏览器加载时的已经有了的状态,相当于提前加载。

注意: 'animation-delay': '-10'+2*rel+'s',

rel是点击时在HTML属性上传来的 全局变量

为什么乘以 2?

看关键帧和动画加载完成时间。总时间是10S;关键帧分为5段,所有10除以5得2。

css3动画使用技巧之—JQ配合css3实现轮播之animation-delay应用的更多相关文章

  1. JS、JQ实现焦点图轮播效果

    JS实现焦点图轮播效果 效果图: 代码如下,复制即可使用: (不过里面的图片路径需要自己改成自己的图片路径,否则是没有图片显示的哦) <!DOCTYPE html> <html> ...

  2. css3动画使用技巧之—border旋转时的应用。

    <html> <head> <title>css3动画border旋转时的应用.</title> <meta charset="UTF- ...

  3. css3动画使用技巧之——transform-delay为负值时的应用。

    <html>    <head>        <title>css3动画delay为负值时的效果</title>        <meta ch ...

  4. 用JQ去实现一个轮播效果

    前提:用JQ去实现轮播效果一步步的做一个梳理. 首先肯定是轮播的HTML和CSS样式了: <body> <div class="pic"> <div ...

  5. 基于JQ的简单左右轮播图

    // 轮播图 主要实现思想: a.第一层div,设置overflow为hidden. b.里面是一个ul,每个li里面有个img或者为每个li设置背景图片也可以. c.li设置为左浮动,排成一行,还有 ...

  6. jQ实现的一个轮播图

    众所周知,轮播图是被广泛的运用的. 轮播图我们在很多的网站上都可以看到,例如淘宝.京东这些网站都很常见. 下面开始我们的轮播之旅: 搭建我们的骨架: <!DOCTYPE html> < ...

  7. jQ实现图片无缝轮播

    在铺页面的过程中,总是会遇到轮播图需要处理,一般我是会用swiper来制作,但总会有哪个几个个例需要我自己来写功能,这里制作了一个jq用来实现图片无缝轮播的dome,分享给大家ヽ( ̄▽ ̄)ノ. dom ...

  8. jq交叉淡入淡出轮播图

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

  9. 原生js+css3实现图片自动切换,图片轮播

    运用CSS3transition及opacity属性 制作图片轮播动画 自己这两天根据用js来控制触发CSS3中transition属性,从而写出来的以CSS3动画为基础,js控制过程的图片轮播 运用 ...

随机推荐

  1. DataTable 导出到 Excel 类

    底层类: #region DataTable 导出到 Excel /// <summary> /// DataTable 导出到 Excel /// </summary> // ...

  2. IOS获取物理尺寸中7Plus中获取的是7的物理尺寸

    IOS获取物理尺寸中7Plus中获取的是7的物理尺寸: 在开发调试过程中我的7Plus手机获取[uiscreen mainscreen].bounds为750  .1334. 解决方案:在手机中的显示 ...

  3. spring问题org.springframework.beans.factory.CannotLoadBeanClassException

    1.看jdk是否配置正确 2.把MyEclipse里面的那个classes删除让他重新编译就没什么问题了,只要配置是对的 3.重新clean project

  4. Codeforces 439D Devu and his Brother 三分

    题目链接:点击打开链接 = - =曾经的三分姿势不对竟然没有被卡掉,,,太逗.. #include<iostream> #include<string> #include< ...

  5. UVALive 6088 Approximate Sorting 构造题

    题目链接:点击打开链接 题意: 给定一个n*n的01矩阵 我们跑一下例子== 4 0111 0000 0100 0110 0123 \|____ 0|0111 1|0000 2|0100 3|0110 ...

  6. android104 帧动画,补间动画,属性动画

    ##帧动画FrameAnimation* 多张图片快速切换,形成动画效果* 帧动画使用xml定义 package com.itheima.frameanimation; import android. ...

  7. RHCA442学习笔记-Unit11内存回收

       Unit 12 Memory Reclamation 内存回收            学习目标:                    A. 了解和调整内存回收                  ...

  8. qt 共享内存(QSharedMemory)

    ——————————————————写入部分—————————————————— (本次程序基于控制台程序) 首先 使用共享内存得召唤一下: #include <QSharedMemory> ...

  9. 职场PPT达人装酷的13条秘诀

    对<说服力-让你的PPT会说话>读者调查显示,88.8%的白领认为“做出漂亮的幻灯片对晋升有帮助”,99.9%的白领一致认为职场装酷神器排行榜第一位是PPT,甚至有位程序员说哥最牛的编程环 ...

  10. ERROR 1114 (HY000): The table 'adv_date_tmp' is full(Mysql临时表应用)

    场景:需要对现在数据库的数据进行批量的进行is_del=1的操作,但是遇到一个问题,在执行sql的时候发现sql不能在查询特定表的时候再嵌套查询来做update的操作,经过讨论,后续我们想到用临时表的 ...