jQuery动画

jQuery注意点

  1、JQuery 定义了 fadeIn() 和 fadeOut() 等简单方法来实现常见的视觉效果,还定义了一个 animate() 方法来实现更复杂的自定义动画

  2、JQuery 动画是异步的,动画方法会在动画完成之前返回

  3、JQuery 动画方法常使用动画时长(用毫秒数值或字符串来表示)作为第一个可选参数,忽略时长参数或指定时长JQuery无法识别时会采用默认值 400ms,字符串 "fast" 表示 200ms、"slow" 表示 600ms。同时,我们可以通过JQuery.fx.speeds["new speed"] = speed 来定义新的时长名字以及其数值

  4、JQuery 动画默认是队列化的,即如果已有一个动画在执行,新的动画需要等当前动画执行完才能执行

  5、stop([bool], [bool]) 方法用来停止当前正在执行的任何动画,第一个可选参数为 true ,则会清除选中元素上的元素队列,并取消任何等待执行的动画,为 false 时则不会取消等待执行的动画;第二个可选参数为 true 时会让指定元素停止到最终值,而 false 则会让元素状态停止在它被触发时的状态

  6、delay(speed, [queueName]) 方法直接添加一个时间延迟到动画队列里,第一个参数是时长,第二个参数是队列名(通常不需要)

 

一、show()方法和hide()方法
1.show()与hide()   给参数就有动画,不给默认为切换display:block。
2.参数:参数一:执行动画的时长 slow,normal,fast,数值(以毫秒为单位)也可以给毫秒数
    参数二:动画执行完毕后的回调函数
 
注:对元素使用带参数的show()和hide()是从:高度,宽度,不透明度  三个属性同时进行操作的。
例如:若对一个<div>(矩形)使用hide(600)。hide(600)会同时减少"矩形"的高度、宽度和不透明度,直到3个属性的值都为0,最后设置该元素的CSS规则为"display:none"。同理show(600)则会从该元素上到下增加“矩形”高度,左到右增大“矩形”的宽度,同时增加“矩形”的不透明度,直至矩形完全显示出来。

二、fadeIn()方法和fadeOut()方法
fadeIn()/fadeOut() 只改变元素的不透明度。
fadeOut()   :会在指定的一段时间内降低元素的不透明度,直到元素完全消失("display:none")。
fadeIn()      :与fadeOut()完全相反。
参数:参数1 : 执行动画的时长 可以直接个毫秒数  也可以给特殊值("slow"  "normal"  "fast") 默认值是normal
   参数2 : 动画执行完毕之后的回调函数
例:

三、slideUp()方法和slideDown()方法
slideUp()/slideDown()只改变元素的高度。
slideDown():如果一个元素的display属性值为"none",当调用slideDown()时,这个元素将由上至下延伸显示。
slideUp()     :与slideDown()完全相反。
参数:参数1 : 执行动画的时长 可以直接个毫秒数  也可以给特殊值("slow"  "normal"  "fast") 默认值是normal
   参数2 : 动画执行完毕之后的回调函数
例:

四、自定义动画方法animate()
animate(params, speed ,callback);
animate的参数:
      参数一:动画执行的属性 必填项 而且它是一个对象
      参数二:动画的运动时长
      参数三:运动曲线 linear 匀速  swing缓动 默认值
      参数四:回调函数(当前动画自行完毕之后执行的函数)
1.自定义简单动画
例:
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 
 4 <head>
 5     <meta charset="UTF-8">
 6     <title>animate</title>
 7     <!-- // 引入 JQuery 库 -->
 8     <script src="http://libs.baidu.com/jquery/2.1.1/jquery.min.js"></script>
 9     <script>
10         // 通过 $(function) 来执行 JQuery 代码
11         $(function() {
12             // 点击button1让div1设置宽高度以及运动过程中的透明度,最后给个回调函数
13             $("#button1").click(function() {
14                 $("#div1").animate({
15                     height: '300px',
16                     opacity: '0.8'
17                 });
18                 $("#div1").animate({
19                     width: '300px',
20                     opacity: '0.4'
21                 });
22                 $("#div1").animate({
23                     height: '100px',
24                     opacity: '0.8'
25                 });
26                 $("#div1").animate({
27                     width: '100px',
28                     opacity: '1'
29                 }, function() {
30                     alert("Hello Animate");
31                 });
32             });
33             $("#button2").click(function() {
34                 $("#div1").stop(true, true);
35             });
36             $("#button3").click(function() {
37                 $("#div2").animate({
38                     left: '200px',
39                     fontSize: '2em',
40                     textAlign: 'center'
41                 });
42             });
43             $("#button4").click(function() {
44                 $("#div2").animate({
45                     left: '0px',
46                     fontSize: '1em',
47                     textAlign: 'left'
48                 });
49             });
50         });
51     </script>
52 </head>
53 <p>
54     <button id="button1">开始动画</button> <button id="button2">停止动画</button>
55     <p>默认情况下,所有的 HTML 元素有一个静态的位置,且是不可移动的。如果需要改变为,我们需要将元素的 position 属性设置为 relative, fixed, 或 absolute!</p>
56     <div id="div1" style="background:#98bf21;height:100px;width:100px;position:fixed;">
57     </div><br/><br/><br/><br/><br/><br/><br/>
58     <button id="button3">开始运动</button> <button id="button4">恢复原状态</button><br/><br/>
59     <div id="div2" style="background-color: #98bf21; height: 100px; width: 100px; position: fixed;">
60         Hello World
61     </div>
62     </body>
63 
64 </html>

注:默认情况下,所有的 HTML 元素有一个静态的位置,且是不可移动的。如果需要改变为,我们需要将元素的 position 属性设置为 relative, fixed, 或 absolute!

  动画只支持数值属性,对于颜色、字体或 display 等枚举属性无法实现动画效果,但我们可以传入自定义的 CSS 属性变化函数来支持非数值动画

  fadeOut() 会让元素看不见,但其在文档里的布局仍然保存着,而 hide() 则会让元素从布局中移除

posted @ 2020-10-24 16:31  花开荼蘼Ⅴ彼岸未归  阅读(167)  评论(0编辑  收藏  举报