深入理解jquery自定义动画animate()

在以前很长一段时间里,网页上的各种特效还需要采用flash 在进行。但最近几年里,我们已经很少看到这种情况了,绝大部分已经使用JavaScript 动画效果来取代flash。这里

说的取代是网页特效部分,而不是动画。网页特效比如:渐变菜单、渐进显示、图片轮播等;而动画比如:故事情节广告、MV 等等。

如果复制当前代码进行在本地测试的时候,请注意把不需要(其他功能展示)的代码注释掉。

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title></title>
  <script src="jquery-1.11.2.js"></script>
  <style type="text/css">
    #box {
      width: 100px;
      height: 100px;
      background-color: red; 

      position:absolute;
    } 

    #pox {
      width: 100px;
      height: 100px;
      background-color: green;
      position: absolute;
      top: 200px;
    }
  </style>
</head>
<body>
  <input type="button" class="button" value="开始" /><input type="button" class="stop" value="停止" />
  <input type="button" class="ani" value="查找运动中的动画" /> 

  <div id="box">box</div>
  <div id="pox">pox</div>
</body>
</html>
<script type="text/javascript">
  $(function () { 

    $(".button").click(function () {
      $("#box").animate({
        left: "300px"  //要想使用left top bottom right这种方向性的属性 先必须对"#box元素设置CSS 绝对定位
      })
    }) 

    //自定义动画中,每次开始运动都必须是初始位置或初始状态,而有时我们想通过当前位置或状态下再进行动画。jQuery 提供了自定义动画的累加、累减功能。
    $(".button").click(function () {
      $("#box").animate({
        left: "+=50px" //每点击一次.button按钮,#box元素就往左移动50px
      })
    }) 

    //-------------------------------------同步动画  

    //一个CSS 变化就是一个动画效果,下面的例子中,已经有四个CSS 变化(分别是width,height,opacity,fontSize的变化)实现了多重动画同步运动的效果。(所谓多重同步运动的效果就是,这四个css属性的值在同一时间,同时变化) 

    $(".button").click(function () {
      $("#box").animate({
        width: "300px",
        height: "200px",
        opacity:0.5, //透明度为0.5 注:透明度的值在0-1之间
        fontSize:"200px", //字体大小设为30px
      }) //第一个参数:是一个对象,他是键值对的css
    }) 

    //--------------------------------------列队动画  

    //通过回调函数现实队列动画。(效果就是:首先#box的宽度变为300px 然后高度变为200px,然后透明度变为50%,字体大小变为150px 最后弹出一个“完毕”)
    $(".button").click(function () {
      $("#box").animate({ width: "300px"}, 1000, function(){
        $("#box").animate({height:"200px"},1000,function(){
          $("#box").animate({opacity:0.5},1000,function(){
            $("#box").animate({fontSize:"150px"},1000,function(){alert("完毕")})
          });
        });
      });
    }) 

    //在同一个元素的基础上,使用链式调用也可以实现列队动画
    $(".button").click(function () {
      $("#box")
        .animate({ width: "300px" }, 1000)
        .animate({ height: "200px" }, 1000)
        .animate({ opacity: 0.5 }, 1000)
        .animate({ fontSize: "150px" }, 1000, function () { alert("列队动画执行完毕")})
    }); 

    //在同一个元素的基础上,通过依次顺序实现列队动画 (如果有多个元素则不能实现,两个元素之间的动画是同步的。)
    $(".button").click(function () {
      $("#box").animate({ width: "300px" }, 1000);
      $("#box").animate({ height: "200px" }, 1000);
      $("#box").animate({ opacity: 0.5 }, 1000);
      $("#box").animate({ fontSize: "150px" }, 1000, function () { alert("列队动画执行完毕")}); 

    }) 

    //如果有多个元素则不能实现 不信请看下面代码 (通过执行下面这段代码,我们发现#box 与#pox这两个元素的动画是同时执行的,属于#box的那两段动画是先执行 $("#box").animate({ width: "300px" }, 1000)然后再执行("#box").animate({ opacity: 0.5 }, 1000); 他们两个有列队动画的效果) 而属于#pox的两段动画是先执行 $("#pox").animate({ height: "200px" }, 1000)然后再执行 $("#pox").animate({ fontSize: "150px" }, 1000)他们两个有列队动画的效果。 但是 $("#box").animate({ width: "300px" }, 1000)与$("#pox").animate({ height: "200px" }, 1000); 同时执行的。 $("#box").animate({ opacity: 0.5 }, 1000)与$("#pox").animate({ fontSize: "150px" }, 1000)是同时执行的。
    //前面说了这么一大堆 其实就是:
    //#box的第一条和第三条是列队动画
    //#pox的第二条和第四条是列队动画 

    //#box的第一条和#pox的第二条是同步动画
    //#box的第三条和#pox的第四条是同步动画 

    $(".button").click(function () {
      $("#box").animate({ width: "300px" }, 1000);
      $("#pox").animate({ height: "200px" }, 1000);
      $("#box").animate({ opacity: 0.5 }, 1000);
      $("#pox").animate({ fontSize: "150px" }, 1000, function () { alert("列队动画执行完毕")});
    }) 

    //那我们现在的需求是:不管你有几个元素,我都要他们依次实现列队动画效果。(测试了一下,只能用这种回调函数嵌套的方式来实现了) 

    $(".button").click(function () {
      $("#box").animate({ width: "300px" }, 1000, function () {
        $("#pox").animate({ height: "200px" }, 1000, function () {
          $("#box").animate({ height: "200px"}, 1000, function () {
            $("#pox").animate({ fontSize: "150px" }, 1000, function () { alert("列队动画执行完毕") });
          })
        })
      })
    }) 

    // ---------------------------------动画与非动画 进行队列 【queue()】 

    //我们知道动画可以有列队效果。但是一个普通的css(比如改变背景颜色)如果实现与动画进行列队呢?
    $(".button").click(function () {
      $("#box").slideUp(1000).slideDown(1000).css("background", "yellow")
    }) 

    //本来我们是想要实现队列动画的,也就是先让#box滑动隐藏,然后再让它滑动显示,最后让它改变颜色。可是我们运行这段呢代码,我们看到第一时间就执行了css("background","yellow")这段代码。
    //通过上面的代码我们了解到 css()方法不是动画方法,会和第一个动画同时执行。也就是说非动画不能列队。 

    //现在问题又来了。我现在想要实现列队动画,也想非动画和动画一起列队怎么办呢? 其实我们可以使用回调函数实现的。请看下面的代码 

    $(".button").click(function () {
      $("#box")
        .slideUp(1000)
        .slideDown(1000, function () { $(this).css("background", "yellow") })
        .hide(3000);
    }) 

    //但如果上面这样的话,当列队动画繁多的时候,可读性不但下降,而原本的动画方法不够清晰。所以,我们的想法是每个操作都是自己独立的方法。那么jQuery 提供了一个类似于回调函数的方法:.queue() 

    $(".button").click(function () {  //三个动画。
      $("#box")
        .slideUp(1000)
        .slideDown(1000)
        .queue(function () { $(this).css("background", "yellow");})
    }) 

    //现在,我们想继续在.queue()方法后面再增加一个隐藏动画,这时发现居然无法实现。这是.queue()特性导致的。有两种方法可以解决这个问题,jQuery 的.queue()的回调函数可以传递一个参数,这个参数是next 函数,在结尾处调用这个next()方法即可再链式执行列队动画。 

    //链式编程实现队列动画
    $(".button").click(function () { //四个动画
      $("#box")
        .slideUp(1000)
        .slideDown(1000)
        .queue(function (next) { //这个next是一个函数
          $(this).css("background", "yellow");
          next();})
        .hide(1000);
    }); 

    //顺序编程实现队列动画 我们看到使用顺序调用的列队,逐个执行,非常清晰
    $(".button").click(function () {
      $("#box").slideUp(1000);
      $("#box").slideDown(1000);
      $("#box").queue(function (next) {
        $(this).css("background", "yellow");
        next(); });
      $("#box").hide(1000);
    }); 

    //因为next 函数是jQuery1.4 版本以后才出现的,而之前我们普遍使用的是.dequeue()方法。意思为执行下一个元素列队中的函数。
    //使用.dequeue()方法执行下一个函数动画
    //$(".button").click(function () {
    //  $('#box').slideUp('slow').slideDown('slow').queue(function () {
    //    $(this).css('background', 'orange');
    //    $(this).dequeue(); //相当于上面的那句next() 只是这里的function()括号里不像上面那样需要传递一个next函数
    //  }).hide(1000)
    //}); 

    //-----------------------------动画的清除 【clearQueue()】 

    //jQuery 还提供了一个清理列队的功能方法:.clearQueue()。把它放入一个列队的回调函 数或.queue()方法里,就可以把剩下为执行的列队给移除。 

    //清理动画列队 

    //假如我想在执行完第二个动画那就就不再执行了。那么只要在第二个动画的回调函数哪里添加一句$(this).clearQueue()就可以停止后面的列队动画了
    $(".button").click(function () { 

      $("#box")
        .slideUp(1000)
        .slideDown(1000, function () { $(this).clearQueue() })
        .queue(function (next) { $(this).css("background", "yellow"); next() })
        .hide(1000);
    }) 

    //那么如果获取列队动画的长度呢?  

    function getQueueCount() {
      return $("#box").queue("fx").length; //获取当前列队的长度,fx 是默认列队的参数
    } 

    //用法
    $(".button").click(function () { 

      //下面这段代码总共有slideUp,slideDown,queue,hide这四个动画
      $("#box")
        .slideUp(1000, function () { alert(getQueueCount()) }) //执行到这一步的时候会打印出:4 它后面还有三个动画,所以下一步的时候会打印出3
        .slideDown(1000, function () { alert(getQueueCount()) }) //执行到这一步的时候会打印出:3
        .queue(function (next) { alert(getQueueCount()); $(this).css("background", "yellow"); next() }) //执行到这一步的时候会打印出:2
        .hide(1000, function () { alert(getQueueCount()) }); //执行到这一步的时候会打印出:1 

    }); 

    //---------------------------------动画的停止【stop()】 

    //很多时候需要停止正在运行中的动画,jQuery 为此提供了一个.stop()方法。它有两个可选参数:.stop(clearQueue, gotoEnd);clearQueue 传递一个布尔值,代表是否清空未执行完的动画列队,gotoEnd 代表是否直接将正在执行的动画跳转到末状态。 

    $(".button").click(function () {
      $("#box")
        .animate({left:"1000px"} ,3000)
    }) 

    $(".stop").click(function () {
      $("#box").stop(); //将#box这个元素的动画停止掉。没有参数的stop()方法只是单纯的停止动画
    }) 

    //那下面再来了解下,列队动画的停止 

    $(".button").click(function () {
      $("#box").animate({ left: "300px" },1000)
           .animate({ bottom: "300px" }, 1000)
           .animate({ width: "300px" }, 1000)
           .animate({ height: "300px" }, 1000)
    }) 

    //$(".stop").click(function () {
    //  $("#box").stop(); // 如果用没有参数的stop()方法去停止有列队动画,那么只会停止掉第一个列队动画,后面的列队动画会继续执行。
    //}) 

    //那么现在我想当我点击停止按钮的时候,我就需要整个将列队动画停止下来,而不是仅仅停止第一个,怎么办呢? 答案是:我们可以给stop()方法加参数
    //stop()方法有两个可选参数:
    //第一个可选参数,如果为true,就代表停止并清除掉后面的队列动画。即:动画完全停止(默认值为false)
    //第二个可选参数,如果为true,就代表停止并清除掉后面的队列动画,并且当前动画会立刻跳转到当前这条动画执行完毕的末尾位置(默认为false)
    $(".stop").click(function () { $("#box").stop(true, true); }) 

    //--------------------------------动画的延迟【delay()】 

    $(".button").click(function () {
      $("#box").delay(2000)    //如果delay(2000) 直接写在$("#box")元素后面,就表示延迟2秒再执行动画
        .animate({ left: "300px" }, 1000)
        .animate({ bottom: "300px" }, 1000)
        .animate({ width: "300px" }, 1000).delay(3000) // 写在这里表示等animate({ width: "300px" }, 1000)这段代码执行完后,延迟3秒再执行下面的代码
        .animate({ height: "300px" }, 1000)
    }) 

    //-----------------------------------获取当前正在执行的动画 【:animated 过滤器】 

    $(".button").click(function () {
      //$("#box").slideUp(1000, function abc() {
      //  $(this).slideToggle(1000, abc); //无限循环的调用自己。实现动画不停的执行。
      //})
      //或者用这以下这种方式也可以实现 动画不停的自执行
      $("#box").slideToggle(1000, function () {
        $(this).slideToggle(1000, arguments.callee); //arguments.callee表示调用自身。 和上面那一句是一样的
      }) 

    }) 

    $(".ani").click(function () {
      $(":animated").css("background", "blue").stop(true); //获取当前正在执行的动画,并将它的颜色改为蓝色后停止动画的执行
    }) 

    //---------------------动画的全局属性【$.fx.off属性可以关闭页面上所有的动画】【$.fx.interval属性可以调整动画每秒运行的帧数】 

    //$.fx.interval 属性用于设置jQuery动画每隔多少毫秒绘制一帧图像 (默认为13 毫秒) 数字越小越流畅,但可能影响浏览器性能。 

    //$.fx.interval = 100; // 设置动画绘制一帧帧的时间为100毫秒,(默认是13毫秒) 

    //$.fx.off = true; //关闭页面上所有的动画 

    //补充:在.animate()方法中,还有一个参数,easing 运动方式,这个参数,大部分参数值需要通过插件来使用,在后面的课程中,会详细讲解。自带的参数有两个:swing(缓动)、linear(匀速),默认为swing。
    $('.button').click(function () { 

      $('#box').animate({ left: '800px' }, 1000, 'swing'); //swing 表示缓动运行,缓速运动有个特点,就是刚开始运行的慢,到了中间就比较快,最后又慢下来(中间快,两头慢) 整段代码的意思就是在1秒钟内 以缓动方式运行动画 

      $('#pox').animate({ left: '800px' }, 1000, 'linear'); //linear表示匀速运行,速度一直不变 整段代码的意思就是在1秒钟内 以匀速方式运行动画
    });
  });
</script> 

以上这篇深入理解jquery自定义动画animate()就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • jQuery Ajax 加载数据时异步显示加载动画

    ajax加载后台数据就不说的那么细了. 看下面代码首先前台上放置代码 <div id="loadgif" style="width:66px;height:66px;position:absolute;top:50%;left:50%;"> <img alt="加载中..." src="../../Images/loading1.gif"/> </div> 在js脚本文件中首先把这个图片动画

  • jQuery实现图像旋转动画效果

    废话不多说了,直接给大家贴代码了,具体代码如下所示: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <tit

  • jQuery实现点击水纹波动动画

    jQuery点击水纹波动动画原理: 1.在需要实现水波纹效果的标签中添加<XXX class="ripple-wrapper"></XXX>     2.代码会定位 鼠标相对 与 标签的位置,以鼠标点为圆心画圆     3.圆的半径 可以自定义(默认为标签的最大宽或高度)     4.圆点颜色,和动画时间等可以自行修改内部代码,或直接 调用 $().css({})方法 进行覆盖 ripple-wrapper.js $(function(){ $(".r

  • 原生js仿jquery animate动画效果

    jquery animate动画效果: 代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>动画</title> <style> *{margin:0;padding:0;} .box{width: 400px;height: 300px;background: #000;margin:40

  • 详解jQuery中基本的动画方法

    大致介绍 通过jQuery中基本的动画方法,能够轻松地为网页添加非常精彩的视觉效果,给用户一种全新的体验 jQuery中的动画 show()和hide()方法 1.show()方法和hide()方法是jQuery中最基本的方法,hide()方法会将一个元素的display设置为"none": 2.show()方法和hide()方法会同时改变元素的宽度.高度和透明度 3.在一个元素使用hide()方法时会记录原先的display属性,当调用show()方法的时候会根据hide()方法记住

  • jQuery动画效果图片轮播特效

    从这一章节开始,我将会为大家陆续的介绍利用Jquery完成特效动画.先来看看这一节所介绍的特效:传统轮播. 一.需求分析 1. 提供很多尺寸相等的图片,一排紧挨着显示. 2. 左右有两个切换按钮,用来控制显示上一张还是下一张. 3. 右下方有指示器"小圈圈",用来提示显示到第几个图片:也可以点击它,进行图片的切换. 4. 每隔一个固定的时间,图片会自动滚动. 5. 当鼠标放到图片上面的时候,会停止自动滚动:当鼠标离开后,再经过固定间隔时间后,又会自动播放. 二.代码剖析 1. 用htm

  • jQuery之动画效果大全

    下面介绍了几种动画效果的方法,具体如下: 1.show()显示效果 语法:show(speed,callback) Number/String,Function speend为动画执行时间,单位为毫秒.也可以为slow","normal","fast" callback可选,为当动画完成时执行的函数. show(speed,[easing],callback) Number/String easing默认是swing,可选linear; $("#

  • 利用jquery制作滚动到指定位置触发动画

    利用CSS3的 animation 动画特性来完成的,对IE的兼容性不是太好,适用与手机端. <!doctype html> <html> <head> <meta charset="utf-8"> <title>sas</title> <script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/1.

  • jQuery中使用animate自定义动画的方法

    动画 animate() 01.animate()方法的简单使用 有些复杂的动画通过之前学到的几个动画函数是不能够实现,这时候就是强大的animate方法了. 操作一个元素执行3秒的淡入动画,对比下一下2组动画设置的区别. $(elem).fadeOut(3000) $(elem).animate({ opacity:0 },3000) 显而易见,animate方法更加灵活了,可以精确的控制样式属性从而执行动画. 语法: 1 .animate( properties [, duration ]

  • jQuery实现的背景颜色渐变动画效果示例

    本文实例讲述了jQuery实现的背景颜色渐变动画效果.分享给大家供大家参考,具体如下: 完整实例代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" c

  • 基于jquery fly插件实现加入购物车抛物线动画效果

    先给大家展示下效果图: 在购物网站中,加入购物车的功能是必须的功能,有的网站在用户点击加入购物车按钮时,就会出现该商品从点击出以抛物线的动画相似加入购物车,这个功能看起来非常炫,对用户体验也有一定的提高.下面介绍基于jquery fly插件实现加入购物车抛物线动画效果. 使用jquery.fly插件很方便时实现抛物线动画加入购物车的功能 一.插件下载 插件官方:https://github.com/amibug/fly 二.载入jQuery库文件和jquery.fly.min.js插件 <scr

  • jQuery动画_动力节点节点Java学院整理

    用JavaScript实现动画,原理非常简单:我们只需要以固定的时间间隔(例如,0.1秒),每次把DOM元素的CSS样式修改一点(例如,高宽各增加10%),看起来就像动画了. 但是要用JavaScript手动实现动画效果,需要编写非常复杂的代码.如果想要把动画效果用函数封装起来便于复用,那考虑的事情就更多了. 使用jQuery实现动画,代码已经简单得不能再简化了:只需要一行代码! 让我们先来看看jQuery内置的几种动画样式: show / hide 直接以无参数形式调用show()和hide(

随机推荐