JQuery之动画

2021-01-29 18:15

阅读:741

YPE html>

标签:不执行   jquery   orm   line   fixed   color   去掉   状态   sel   

一、显示动画

方式一:

```javascript
$("div").show();
```

解释:无参数,表示让指定的元素直接显示出来。其实这个方法的底层就是通过`display: block;`实现的。

方式二:

```javascript
$("div").show(2000);
```

解释:通过控制元素的宽高、透明度、display属性,逐渐显示,2秒后显示完毕。

方式三:

```javascript
$("div").show("slow");
```

参数可以是:

- slow 慢:600ms

- normal 正常:400ms

- fast 快:200ms

解释:和方式二类似,也是通过控制元素的宽高、透明度、display属性,逐渐显示。

方式四:

```javascript
//show(毫秒值,回调函数;
$("div").show(5000,function () {
alert("动画执行完毕!");
});
```

解释:动画执行完后,立即执行回调函数。

**总结:**

上面的四种方式几乎一致:参数可以有两个,第一个是动画的执行时长,第二个是动画结束后执行的回调函数。

二、隐藏动画

方式参照上面的show()方法的方式。如下:

```javascript
$(selector).hide();

$(selector).hide(1000);

$(selector).hide("slow");

$(selector).hide(1000, function(){});
```

**显示和隐藏的来回切换:**

显示和隐藏的来回切换采用的是toggle()方法:就是先执行show(),再执行hide()。

同样是四种方式:

```javascript
$(selector).toggle();

```

三、滑入和滑出

**1、滑入动画效果**:(类似于生活中的卷帘门)


```javascript
$(selector).slideDown(speed, 回调函数);
```

解释:下拉动画,显示元素。

注意:省略参数或者传入不合法的字符串,那么则使用默认值:400毫秒(同样适用于fadeIn/slideDown/slideUp)


**2 滑出动画效果:**

```javascript
$(selector).slideUp(speed, 回调函数);
```

解释:上拉动画,隐藏元素。


**3、滑入滑出切换动画效果:**

```javascript
$(selector).slideToggle(speed, 回调函数);
```

参数解释同show()方法。

举例:

```html






//滑入动画: slideDown(毫秒值,回调函数[显示完毕执行什么]);
$("div").slideDown(2000, function () {
alert("动画执行完毕!");
});
})

//滑出动画
$("button:eq(1)").click(function () {

//滑出动画:slideUp(毫秒值,回调函数[显示完毕后执行什么]);
$("div").slideUp(2000, function () {
alert("动画执行完毕!");
});
})

$("button:eq(2)").click(function () {
//滑入滑出切换(同样有四种用法)
$("div").slideToggle(1000);
})

})








```

技术图片

四、淡入淡出动画

1、淡入动画效果:

```javascript
$(selector).fadeIn(speed, callback);
```

作用:让元素以淡淡的进入视线的方式展示出来。

2、淡出动画效果:

```javascript
$(selector).fadeOut(1000);
```

作用:让元素以渐渐消失的方式隐藏起来

3、淡入淡出切换动画效果:


```javascript
$(selector).fadeToggle(‘fast‘, callback);
```

作用:通过改变透明度,切换匹配元素的显示或隐藏状态。

参数的含义同show()方法。

代码举例:

```html






// //淡入动画用法2: fadeIn(2000); 毫秒值
// $("div").fadeIn(2000);
// //通过控制 透明度和display

//淡入动画用法3: fadeIn(字符串); slow慢:600ms normal正常:400ms fast快:200ms
// $("div").fadeIn("slow");
// $("div").fadeIn("fast");
// $("div").fadeIn("normal");

//淡入动画用法4: fadeIn(毫秒值,回调函数[显示完毕执行什么]);
// $("div").fadeIn(5000,function () {
// alert("动画执行完毕!");
// });
})

//滑出动画
$("button:eq(1)").click(function () {
// //滑出动画用法1: fadeOut(); 不加参数
// $("div").fadeOut();

// //滑出动画用法2: fadeOut(2000); 毫秒值
// $("div").fadeOut(2000); //通过这个方法实现的:display: none;
// //通过控制 透明度和display

//滑出动画用法3: fadeOut(字符串); slow慢:600ms normal正常:400ms fast快:200ms
// $("div").fadeOut("slow");
// $("div").fadeOut("fast");
// $("div").fadeOut("normal");

//滑出动画用法1: fadeOut(毫秒值,回调函数[显示完毕执行什么]);
// $("div").fadeOut(2000,function () {
// alert("动画执行完毕!");
// });
})

$("button:eq(2)").click(function () {
//滑入滑出切换
//同样有四种用法
$("div").fadeToggle(1000);
})

$("button:eq(3)").click(function () {
//改透明度
//同样有四种用法
$("div").fadeTo(1000, 0.5, function () {
alert(1);
});
})
})









```

五、自定义动画

```javascript
$(selector).animate({params}, speed, callback);
```

作用:执行一组CSS属性的自定义动画。

- 第一个参数表示:要执行动画的CSS属性(必选)

- 第二个参数表示:执行动画时长(可选)

- 第三个参数表示:动画执行完后,立即执行的回调函数(可选)

代码举例:

```html














```

六、停止动画

```javascript
$(selector).stop(true, false);
```

**里面的两个参数,有不同的含义。**

第一个参数:

- true:后续动画不执行。

- false:后续动画会执行。

第二个参数:

- true:立即执行完成当前动画。

- false:立即停止当前动画。

PS:参数如果都不写,默认两个都是false。实际工作中,直接写stop()用的多。

**效果演示:**

当第二个参数为true时,效果如下:

技术图片

当第二个参数为false时,效果如下:

技术图片


这个**后续动画**我们要好好理解,来看个例子。

**案例:鼠标悬停时,弹出下拉菜单(下拉时带动画)**

```html












  • 一级菜单1

    • 二级菜单1

    • 二级菜单2

    • 二级菜单3




  • 一级菜单1

    • 二级菜单1

    • 二级菜单2

    • 二级菜单3




  • 一级菜单1

    • 二级菜单1

    • 二级菜单2

    • 二级菜单3







```

效果如下:

技术图片

上方代码中,关键的地方在于,用了stop函数,再执行动画前,先停掉之前的动画。

如果去掉stop()函数,效果如下:(不是我们期望的效果)

技术图片

stop方法的总结

当调用stop()方法后,队列里面的下一个动画将会立即开始。
但是,如果参数clearQueue被设置为true,那么队列面剩余的动画就被删除了,并且永远也不会执行。

如果参数jumpToEnd被设置为true,那么当前动画会停止,但是参与动画的每一个CSS属性将被立即设置为它们的目标值。比如:slideUp()方法,那么元素会立即隐藏掉。如果存在回调函数,那么回调函数也会立即执行。

注意:如果元素动画还没有执行完,此时调用stop()方法,那么动画将会停止。并且动画没有执行完成,那么回调函数也不会被执行。


七、举例

右下角的弹出广告

代码实现:

```html







我是内容




```

效果如下:

技术图片

JQuery之动画

标签:不执行   jquery   orm   line   fixed   color   去掉   状态   sel   

原文地址:https://www.cnblogs.com/dangjf/p/13201823.html


评论


亲,登录后才可以留言!