`

Java程序员从笨鸟到菜鸟之(九十一)跟我学jquery(七)jquery动画大体验

阅读更多

本文来自:曹胜欢博客专栏。转载请注明出处:http://blog.csdn.net/csh624366188

最近一直感觉自己好忙,每天都浑浑噩噩的过着,转眼间,好像有好长时间没有更新笨鸟到菜鸟了。现在想想,实在罪过了。自从从北京回来就一直投入不了状态,所以也想利用一下这个写博客的机会来促进自己早日投入状态吧。今天我们要讲的是jquery 动画的东西,其实一说到动画,我相信很多人想到的应该是flash 吧。其实不然,现在我们将要用jquery 来改变flash 的一统天下,当然,我们这里所说的动画和flash 所做的动画还是有很大的区别的。所以也谈不上他两个产品有什么竞争关系,下面我们就先通过一个简单的实例来看一下jquery 的强大吧。

 

在很多web 开发过程中,我们都会用到弹出层的情况,我们再做弹出层的时候大多数都应该用的js 实现把。假设有如下需求 :

· 单击图中的 " 显示提示文字 " 按钮 , 在按钮的下方显示一个弹出

· 单击任何空白区域或者弹出层 , 弹出层消失

 

用原始 javascript 我们也完全可以完成这个工作 . 有以下几点注意事项 :

1. 弹出层的位置需要动态计算 . 因为触发弹出事件的对象可能出现在页面的任何位置 , 比如截图中的位置 .

2. document 绑定单击是关闭弹出层的函数 , 要使用多播委托 , 否则可能冲掉其他人在 document 绑定的函数 .

3. document 绑定了关闭函数后 , 需要在显示函数中取消事件冒泡 , 否则弹出层将显示后立刻关闭

 

· 下面我们来看一下用 jquery 来实现这里的弹出层是怎么实现的:

 

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

    <title>jQuery – 弹出层动画</title>

    <script type="text/javascript" src="jquery-1.7.2.js"></script>

    <script type="text/javascript">

        $(document).ready(function()

        {

            //动画速度

            var speed = 500;

            //绑定事件处理

            $("#btnShow").click(function(event)

            {

                //取消事件冒泡,所谓事件冒泡就是在子控件触发事件时父控件也触发相应的事件

                event.stopPropagation();

                //获得触发事件控件的位置

                var offset = $(event.target).offset();

                            //设置弹出层的位置

                $("#divPop").css({ top: offset.top + $(event.target).height() + "px", left: offset.left });

                //动画显示弹出层

                $("#divPop").show(speed);

            });

            //单击空白区域隐藏弹出层

            $(document).click(function(event) { $("#divPop").hide(speed) });

            //单击弹出层则自身隐藏

            $("#divPop").click(function(event) { $("#divPop").hide(speed) });

        });

    </script>

</head>

<body>

    <div>

        <br /><br /><br />

        <button id="btnShow">弹出层</button>

    </div>

    <!-- 弹出层 -->

    <div id="divPop" style="background-color: #f0f0f0; border: solid 1px #000000; position: absolute; display:none;

        width: 300px; height: 100px;">

        <div style="text-align: center;">这里是弹出层</div>

    </div>

</body>

</html>


从上边代码的效果我们可以看到,利用jquery 除了实现了自动隐藏和弹出层,还实现了动画弹出的效果。这样的效果让我这个初学jquery 的小菜确实欢喜。所以说感觉很有必要专门抽出一篇来讲解一下这个jquery 动画。Ok ,下面我们就一起来正式看一下jquery 动画的东西

 

jQuery 的动画函数主要分为三类 :

基本动画函数 : 既有透明度渐变 , 又有滑动效果 . 是最常用的动画效果函数 .

滑动动画函数 : 仅使用滑动渐变效果 .

淡入淡出动画函数 : 仅使用透明度渐变效果 .

这三类动画函数效果各不相同 , 用法基本一致 . 大家可以自己尝试 . 另外也许上面的三类函数效果都不是我们想要的 , 那么 jQuery 也提供了 自定义动画函数 , 将控制权放在我们手里让我们自己定义动画效果。下面我们就来一一看一下这三种动画函数。

 

. 基本动画函数:
   1 show()
  显示隐藏匹配元素。这个就是 'show( speed, [callback] )' 无动画的版本。如果选择的元素是可见的,这个方法将不会改变任何东西。无论这个元素是通过 hide() 方法隐藏的还是在 CSS 里设置了 display:none; ,这个方法都将有效。
  例如:显示所有段落, $("p").show()
   2 show(speed,[callback])

  以优雅的动画显示匹配的元素,并且在显示完成后可选择返回一个回调函。可根据指定的速度动态改变每个匹配元素高度、宽度和不透明度。
  例如:用缓慢的动画将隐藏的段落显示出来,历时 600 毫秒, $("p").show(600)
   3 hide()

  隐藏显示元素。这个就是 'hide( speed, [callback] )' 的无动画版。如果选择的元素是隐藏的,这个方法将不会改变任何东西。
  例如:隐藏所有段落, $("p").hide()
   4 hide(speed,[callback])

  以优雅的动画隐藏所有匹配的元素,并在显示完成后可选的触发一个回调函数。可以根据指定的速度动态地改变每个匹配元素的高度、宽度和不透明度。在 jQuery 1.3 中, padding margin 也会有动画,效果更流畅。
  例如:用 600ms 的时间将段落缓慢的隐藏, $("p").hide("slow");
   5 toggle

  切换元素的可见状态。如果元素时可见的,切换为隐藏的;如果元素是隐藏的,切换为可见的。
  例如:切换所有段落的可见状态, $("p").toggle()
   6 toggle(switch

  根据 switch 参数切花元素的可见状态 (true 为可见 ,false 为隐藏 ) 。如果 switch 设为 true, 则调用 show() 方法来显示匹配的元素,如果 switch 设为 false 则调用 hide() 来隐藏元素。
  例如:切换所有段落的可见状态, var flip=0;$("button").click(function(){$("p").toggle(flip++%2==0);});
   7
toggle(speed,[callback])
  以优雅的动画切换所有匹配的元素,并在显示完成后可选的触发一个回调函数。可根据指定的速度动态的改变每个匹配元素的高度、宽度和不透明度。 jquery 1.3,padding margin 也会有动画 , 效果更流畅。

  例如:用 200ms 将段落迅速切换显示状态,之后弹出一个对话框, $("p").toggle("fast",function(){alert("hello !");});

 

说明: speed 参数可以使用三种预定速度之一的字符串 ("slow", "normal", or "fast") 或表示动画时长的毫秒数值 ( 如: 1000).

 

. 滑动动画函数

基本动画函数的效果是一个综合了滑动和透明度渐变的函数 , jQuery 还单独提供了只有滑动效果的相关函数 .

 

 

名称

说明

举例

slideDown(speed, [callback])

通过高度变化(向下增大)来动态地显示所有匹配的元素,在显示完成后可选地触发一个回调函数。

这个动画效果只调整元素的高度,可以使匹配的元素以 滑动 的方式显示出来。在 jQuery 1.3 中,上下的 padding margin 也会有动画,效果更流畅。

600 毫秒缓慢的将段落滑下 : $("p").slideDown("slow");

slideUp(speed, [callback])

通过高度变化(向上减小)来动态地隐藏所有匹配的元素,在隐藏完成后可选地触发一个回调函数。

600 毫秒缓慢的将段落滑上 : $("p").slideUp("slow");

slideToggle(speed, [callback])

通过高度变化来切换所有匹配元素的可见性,并在切换完成后可选地触发一个回调函数。

600 毫秒缓慢的将段落滑上或滑下 : $("p").slideToggle("slow");

说明:

slideDown 就是 show 的滑动效果版本 , slideUp 就是 hide 的滑动效果版本 , slideToggle 就是 toggle 的滑动效果版本 .

参数完全相同 :

$("#divPop").slideDown(200);

$("#divPop").slideUp("fast");

$("#divPop").slideToggle("slow");

 

. 淡入淡出动画函数

淡出淡出函数只提供透明度渐变的效果 .

 

名称

说明

举例

fadeIn( speed, [callback] )

通过不透明度的变化来实现所有匹配元素的淡入效果,并在动画完成后可选地触发一个回调函数。

这个动画只调整元素的不透明度,也就是说所有匹配的元素的高度和宽度不会发生变化。

600 毫秒缓慢的将段落淡入 : $("p").fadeIn("slow");

fadeOut( speed, [callback] )

通过不透明度的变化来实现所有匹配元素的淡出效果,并在动画完成后可选地触发一个回调函数。

600 毫秒缓慢的将段落淡出 : $("p").fadeOut("slow");

fadeTo(speed, opacity, [callback])

把所有匹配元素的不透明度以渐进方式调整到指定的不透明度,并在动画完成后可选地触发一个回调函数。

600 毫秒缓慢的将段落的透明度调整到 0.66 ,大约 2/3 的可见度 : $("p").fadeTo("slow", 0.66);$("p").fadeTo("slow",

 

四、自定义动画函数 Custom
   1 animate(params,[duration],[easing],[callback]) 用于创建自定义动画的函数。这个函数的关键在于制定动画形式及结果样式属性对象。这个对象中每个属性都表示一个可以变化的样式属性(如 height top opacity) 。注意:所有指定的属性必须用骆驼形式,比如用 marginLeft 代替 margin-left 。而每个属性的值表示这个样式属性到多少是动画结束。如果是一个数值,样式属性就会从当前的值渐变到指定的值。如果使用的是 hide show toggle 这样的字符串值,则会就该属性调用默认的动画形式。
  例如:点击按钮后 div 元素的几个不同属性一同变化,
  

$("#go").click(function(){
  $("#block").animate({
  width:"90%",height:"100%",fontSize:"10em",borderWidth:10
  },1000);
  });


   2 stop([clearQueue],[gotoEnd])
  停止所有在指定元素上正在运行的动画。如果队列中有等待执行的动画 ( 并且 clearQueue 没有设为 true) ,他们将被马上执行 clearQueue(Boolean): 如果设置成 true ,则清空队列。可以立即结束动画。 gotoEnd (Boolean): 让当前正在执行的动画立即完成,并且重设 show hide 的原始样式,调用回调函数等。

  例如:点击 Go 之后开始动画 , Stop 之后会在当前位置停下来 :
  

//开始动画
  $("#go").click(function(){
  $(".block").animate({left: '+200px'}, 5000);
  });
  //当点击按钮后停止动画
  $("#stop").click(function(){
  $(".block").stop();
  });

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics