您的位置:首页 > Web前端 > JQuery

jQuery(7)jquery动画大体验

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




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

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



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

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

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

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



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



[html] view
plaincopyprint?

<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元素的几个不同属性一同变化,

  

[html] view
plaincopyprint?

$("#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之后会在当前位置停下来:

  

[html] view
plaincopyprint?

//开始动画

  $("#go").click(function(){

  $(".block").animate({left: '+200px'}, 5000);

  });

  //当点击按钮后停止动画

  $("#stop").click(function(){

  $(".block").stop();

  });

本文借鉴:http://blog.csdn.net/csh624366188/article/details/7850901
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: