一、jQuery动画特效说明

jQuery框架中为我们封装了众多的动画和特效方法,只需要调用对应的动画方法传递合适的参数,就能够方便的实现一些炫酷的效果,而且jQuery框架还支持自定义各种动画效果。

jQuery中的动画效果主要有以下方法

① 显示和隐藏动画

② 展开和收起动画

③ 淡入和淡出动画

④ 自定义动画效果


二、显示和隐藏动画

jQuery框架中为我们提供了专门的方法来控制让标签显示或者是隐藏。标签的显示和隐藏在开发中相对来说是比较常见的操作,如果使用原生的JavaScript代码来控制标签的显示或者是隐藏,那么我们主要通过控制该标签的display属性值来实现。

jQuery中控制标签显示和隐藏的动画方法

① show() 控制让标签显示的动画方法

② hide() 控制让标签隐藏的动画方法

③ toggle()控制让标签显示|隐藏效果切换的动画方法

ex:以原生的方法来控制标签的显示或隐藏


<!DOCTYPE html>
<html lang="en">
<head>
<!--....-->
<style>
#demoID{
width: 200px;
height: 50px;
background: red;
}
</style>
<script src="jquery-3.1.1.js"></script>
</head>
<body>
<div id="demoID"></div>
<script>
//控制标签显示或隐藏的方式(1)
//document.getElementById("demoID").style.display = "none";
//document.getElementById("demoID").style.display = "block"; //控制标签显示或隐藏的方式(2)
//$("#demoID").css("display","none");
$("#demoID").css("display","block");
</script>
</body>
</html>

显示和隐藏动画方法语法

$("selector").show(speed,callBack)

$("selector").hide(speed,callBack)

参数说明:

第一个参数:可选的参数。speed表示执行动画的速度,该速度可以使用系统默认提供的值,也可以自己以数字的形式传入。

系统默认提供的值有:“slow”、“normal”、“fast”,对应的速度分别为0.6秒、0.4秒和0.2秒。

自己以数字的形式传递则:传递如1000|3000类似的值,单位为毫秒,如果传递1000表示动画的执行速度为1秒。

第二个参数:可选的参数。callBack为动画完成时执行的回调函数,该函数每个元素执行一次。

切换动画方法语法

调用方式[1] => $("selector").toggle()

调用方式[2] => $("selector").toggle(speed,callBack)

方法参数说明:

(1)调用方式[1],不传递参数。切换当前元素(标签)的可见状态,如果当前元素的状态为不可见,则切换为可见,如果当前元素的状态为可见,则切换为不可见。

(2)调用方式[2],第一个可选的参数为动画执行的速度,第二个可选的参数为动画执行完后执行的回调函数。

总结

show方法和hide方法用来控制标签的显示或者是隐藏,内部的实现逻辑是同时改变标签的宽度、高度和透明度


三、展开和收起动画

jQuery框架中,为我们提供实现滑动效果的方法,slideDown和slideUp方法分别可以用来控制标签展开和收起。

展开和收起动画方法语法

slideDown(speed,callBack);

slideUp(speed,callBack)

slideToggle(speed,callBack)

方法解释

slideDown方法的功能是设置让指定标签的高度从顶部向底部增加,以呈现出一种展开的动画效果,元素的其他属性不会发生任何变化。

sldeUp方法的功能是设置让指定标签的高度从底部向顶部减小,仅仅改变标签的高度,其他的属性并不会改变。

slideToggle方法用来切换所选择元素的高度,如果当前标签的高度不为0,那么调用该方法后就会把标签的高度过渡为0,实现收起的效果,否则就实现展开的效果。

注意:无论是展开还是收起的动画方法,他们的动画效果都仅仅只会改变(增加或减小)标签的高度。

参数说明

第一个参数:动画执行的时间,同show方法。

第二个参数:动画执行完毕的回调函数,可以省略,同show方法。

代码示例

<body>
<div>我是div</div>
<button>展开</button>
<button>收起</button>
<button>切换</button>
<script>
$(function () {
$("button").eq(0).click(function () {
$("div").slideDown(2000,function () {
console.log("展开");
});
}) $("button").eq(1).click(function () {
$("div").slideUp(2000);
}) $("button").eq(2).click(function () {
$("div").slideToggle(1000,function () {
alert("切换动画指定完毕")
});
})
})
</script>
</body>

四、淡入和淡出动画

jQuery框架中还提供了淡入和淡出的动画方法,这两个方法分别是fadeIn和fadeOut。

淡入和淡出动画方法语法

fadeIn(speed,callBack);

fadeOut(speed,callBack)

fadeToggle(speed,callBack)

fadeTo(speed,opactity,callBack)

方法说明:

淡入淡出方法的内部实现原理是控制标签的透明度,通过改变选中标签的透明度来实现淡入和淡出的动画效果,并不修改其他的属性。

fadeIn()方法的作用是淡入动画,即改变标签的透明度让标签慢慢的显示出来。

fadeOut()方法的作用是淡出动画,即改变标签的透明度让标签慢慢的消失(透明度为0)。

fadeToggle()方法的作用是切换动画,如果当前标签的透明度不为0,那么就执行淡出动画,否则就执行淡入动画。

fadeTo()方法的作用是淡入到,即使用动画效果实现将标签的透明度设置为指定的值。

备注:标签透明度的取值范围为0.0~1.0。

参数说明:

speed参数:动画执行的速度,单位为毫秒。

callBack参数:动画执行完毕的回调函数,可选。

opacity参数:指定的标签透明度(0.0~1.0)。

代码示例

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="JS/jquery-3.2.1.js"></script>
<style>
div{
width: 400px;
height: 200px;
background: red;
}
</style>
</head>
<body>
<div>我是div</div>
<button>淡入</button>
<button>淡出</button>
<button>切换</button>
<button>惦记我</button>
<script> //fadeIn:淡入
//fadeOut:淡出
//fadeToggle切换
//fadeTo:淡入淡出到...0.5 $(function () {
//01 获取页面中指定的按钮,添加点击事件
$("button:eq(0)").click(function () {
//02 点击按钮后,获取页面中的div标签,设置动画
//第一个参数:速度
//第二个参数:回调
$("div").fadeIn(2000,function () {
alert("显示完成");
});
}) $("button:eq(1)").click(function () {
$("div").fadeOut(1000,function () {
alert("淡出")
});
}) $("button:eq(2)").click(function () {
$("div").fadeToggle();
}) $("button:eq(3)").click(function () {
//第一个参数:速度
//第二个参数:目标值
//第三个参数:回调
$("div").fadeTo(1000,0.5,function () {
alert("执行动画完毕")
});
}) }) </script> </body>
</html>

五、自定义动画

jQuery框架中本身已经为我们封装好了一些简单的控制标签宽高、透明度相关的方法,如显示和隐藏、展开和收起、淡入和淡出,除了这些方法之外,jQuery还为我们提供了animate()方法,允许我们自定义动画效果,通过一些设置我们可以实现更加复杂的动画效果,

自定义动画的语法

animate(params,speed,easing,callBack)

参数说明:

第一个参数:params是一个对象。在该对象中以键值对的方式来要控制的属性样式和对应的值表示。

第二个参数:speed速度,可以是默认字符串中的某个(“slow” "normal" "fast")或者是自定义的数字。

第三个参数:easing为动画插件使用的可选参数,用来控制动画的表现效果,通常有linear和swing等固定值。

第四个参数:动画执行完毕后的回调函数。

代码示例

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
div{
width: 200px;
height: 50px;
background: red;
}
</style>
</head>
<body>
<!--
animate({},timer,fn)
第一个参数:目标对象
第二个参数:速度
第三个参数:回调函数
--> <div>我是个好人</div>
<button>
喜欢我就点我吧
</button>
<button>
喜欢我就点我吧2
</button>
<script src="js/jquery-3.2.1.js"></script>
<script>
$(function () {
$("button:eq(0)").click(function () {
$("div").animate({
width:"+=50",
height:"+=100"
},1000);
})
$("button:eq(1)").click(function () {
//01 直接设置目标值:速度和回调函数可以被省略
// $("div").animate({
// width:400,
// height:100
// },2000,function () {
// alert("执行完毕");
// }) //02 第二种用法 // $("div").animate({
// width:"+=50",
// height:"+=100"
// },1000); //03 动画切换(如果有值那么就设置为0,否则就恢复)
$("div").animate({
width:"toggle",
height:"+=100"
},1000);
})
})
</script>
</body>
</html>

动画队列、动画停止和动画延迟

动画队列:如果某个标签身上要调用多个动画相关方法,即需要展示多个动画效果,那么所有的这些动画效果并不会同一时刻发生,而是需要在队列中排队,然后按照队列中动画效果的顺序依次展现。

动画停止:在执行动画的时候,可以通过stop()方法来停止动画。停止动画的语法为:

stop(clearQueue,gotoEnd)

方法和参数说明:

stop方法的功能是停止指定标签中正在执行的动画,其中第一个参数clearQueue为可选参数,传递一个布尔类型的值,表示是否停止正在执行的动画。第二个参数gotoEnd也是可选参数,传递一个布尔类型的值,表示是否立即完成正在执行的动画。

动画延迟:设置一个延时的值来推迟后续队列中动画的执行,可以传递延迟的具体时间,单位为毫秒。

代码示例01

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
div{
width: 200px;
height: 200px;
background: yellow;
}
</style>
</head>
<body>
<div>
</div>
<button>按钮</button>
<script src="js/jquery-3.2.1.js"></script>
<script>
$(function () {
$("button").click(function () {
$("div").animate({
width:"50px"
})
.animate({
height:50
})
.delay(2000)
.animate({
height:300
})
.animate({
width:400
})
})
})
</script>
</body>
</html>

代码示例02

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
div{
width: 50px;
height: 50px;
background: green;
}
</style>
</head>
<body>
<div>
</div>
<button>按钮</button>
<script src="js/jquery-3.2.1.js"></script>
<script>
$(function () { //01 当页面加载完毕就执行动画效果
$("div").animate({
width:"400px"
},2000)
.animate({
height:200
},1000)
.delay(1000)
.animate({
height:50
})
.animate({
width:50
}) //02 当点击按钮的时候停止动画
$("button").click(function () { //01 没有传递参数:结束当前的动画,继续执行后面的动画
//$("div").stop(); //02 传递1参数:
// true:所有的动画全部结束
// false:结束当前的动画,继续执行后面的动画
//$("div").stop(true);
//$("div").stop(false); //03 传递2参数:
//true true : 立刻结束到达当前动画的终点,后面的不再执行
//true false:所有的动画全部结束
//false false:结束当前的动画,继续执行后面的动画
//false true : 立刻结束到达当前动画的终点,后面的继续执行
//$("div").stop(true,true);
//$("div").stop(true,false);
//$("div").stop(false,false);
$("div").stop(false,true);
})
})
</script>
</body>
</html>

前端开发系列069-JQuery篇之框架动画特效的更多相关文章

  1. ABP开发框架前后端开发系列---(9)ABP框架的权限控制管理

    在前面两篇随笔<ABP开发框架前后端开发系列---(7)系统审计日志和登录日志的管理>和<ABP开发框架前后端开发系列---(8)ABP框架之Winform界面的开发过程>开始 ...

  2. openlayers5-webpack 入门开发系列一初探篇(附源码下载)

    前言 openlayers5-webpack 入门开发系列环境知识点了解: node 安装包下载webpack 打包管理工具需要依赖 node 环境,所以 node 安装包必须安装,上面链接是官网下载 ...

  3. leaflet-webpack 入门开发系列一初探篇(附源码下载)

    前言 leaflet-webpack 入门开发系列环境知识点了解: node 安装包下载webpack 打包管理工具需要依赖 node 环境,所以 node 安装包必须安装,上面链接是官网下载地址 w ...

  4. web前端开发学习:jQuery的原型中的init

    web前端开发学习:jQuery的原型中的init 有大量web前端开发工具及学习资料,可以搜群[ web前端学习部落22群 ]进行下载,遇到学习问题也可以问群内专家以及课程老师哟 jQuery.fn ...

  5. jQuery系列 第五章 jQuery框架动画特效

    第五章 jQuery框架动画特效 5.1 jQuery动画特效说明 jQuery框架中为我们封装了众多的动画和特效方法,只需要调用对应的动画方法传递合适的参数,就能够方便的实现一些炫酷的效果,而且jQ ...

  6. 【Windows10 IoT开发系列】配置篇

    原文:[Windows10 IoT开发系列]配置篇 Windows10 For IoT是Windows 10家族的一个新星,其针对不同平台拥有不同的版本.而其最重要的一个版本是运行在Raspberry ...

  7. 基于jQuery加入购物车飞入动画特效

    基于jQuery加入购物车飞入动画特效.这是一款电商购物网站常用的把商品加入购物车代码.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div id="main& ...

  8. 前端开发 vue,angular,react框架对比1

    转载自:https://www.cnblogs.com/hubgit/p/6633214.html 首先,我们先了解什么是MVX框架模式? MVX框架模式:MVC+MVP+MVVM 1.MVC:Mod ...

  9. [置顶]【实用 .NET Core开发系列】- 导航篇

    前言 此系列从出发点来看,是 上个系列的续篇, 上个系列因为后面工作的原因,后面几篇没有写完,后来.NET Core出来之后,注意力就转移到了.NET Core上,所以再也就没有继续下去,此是原因之一 ...

  10. Android Metro风格的Launcher开发系列第三篇

    前言: 各位小伙伴,又到了每周更新文章了时候了,本来是周日能发出来呢,这不是赶上清明节吗,女王大人发话了,清明节前两天半陪她玩,只留给我周一下午半天时间写博客,哪里有女王哪里就有压迫呀有木有!好了闲话 ...

随机推荐

  1. Spring的AoP(面向切面编程)

    作用: 就是把我们程序重复的代码抽取出来,在需要执行的时候,使用动态代理的技术,在不修改源码的 基础上,对我们的已有方法进行增强. 优势: 减少重复代码 提高开发效率 维护方便 AoP的实现方式:动态 ...

  2. python调用QQ机器人向指定QQ发消息

    暂时没想到这个能用来干什么,只是刚好看到相关文章,学习一下,就拿获取基金信息来做试验把 爬取基金的信息就不介绍了,请参考https://www.cnblogs.com/becks/p/14500495 ...

  3. Robot Framework自定义关键字

    需求分析: 如下图,诸多步骤中可能共用某些共同的步骤,比如都需要登录会员 此,可以把登录的操作写成模块化,插入其他脚本供其他脚本调用,如此可以节省不少脚本量 上图为会员登录的操作. 具体实施如下: 1 ...

  4. 聊聊四种实时通信技术:长轮询、短轮询、WebSocket 和 SSE

    这篇文章,我们聊聊 四种实时通信技术:短轮询.长轮询.WebSocket 和 SSE . 1 短轮询 浏览器 定时(如每秒)向服务器发送 HTTP 请求,服务器立即返回当前数据(无论是否有更新). 优 ...

  5. Python3 GUI界面

    一.python gui(图形化)模块介绍: Tkinter :是python最简单的图形化模块,总共只有14种组建 Pyqt :是python最复杂也是使用最广泛的图形化 Wx :是python当中 ...

  6. 牛逼,这款开源聊天应用竟能一键召唤多个AI助手,跨平台通话神器!

    嗨,大家好,我是小华同学,关注我们获得"最新.最全.最优质"开源项目和高效工作学习方法 JiwuChat是一款基于Tauri2和Nuxt3构建的轻量化多平台即时通讯工具,仅约8MB ...

  7. 【MOOC】华中科技大学操作系统慕课答案-单元作业+第1~2章开放性思考题

    单元作业答案如果没大问题的话,多半是直接摘抄自PPT. 文章目录 第一章 操作系统概述 单元作业(1) 开放性思考题 第二章 操作系统逻辑结构 单元作业 开放性思考题 第三章 操作系统用户界面 单元作 ...

  8. Linux系统中的curl命令使用详解

    curl概述 官方文档:https://curl.se/docs/ GitHub地址:https://github.com/curl/curl curl全称Client URL,是一个命令行工具和库, ...

  9. CUDA 线程ID 计算方式

    thread ID 的计算方式,简单来说很像小学学的除法公式,本文转载自同学一篇博客:并进行简单修改: 被除数 = 除数 * 商 + 余数 用公式表示:$$线程Id = blockId * block ...

  10. 第1.1讲:Transformers 的崛起:从RNN到Self-Attention

    序列建模的演进之路 一.RNN( Recurrent Neural Networks):序列处理的开拓者 循环神经网络(RNN)是最早处理序列数据的深度学习结构.RNN的核心思想是在处理序列的每个时间 ...