详解jQuery中基本的动画方法

发布时间 - 2026-01-10 21:48:58    点击率:

大致介绍

通过jQuery中基本的动画方法,能够轻松地为网页添加非常精彩的视觉效果,给用户一种全新的体验

jQuery中的动画

show()和hide()方法

1、show()方法和hide()方法是jQuery中最基本的方法,hide()方法会将一个元素的display设置为"none";

2、show()方法和hide()方法会同时改变元素的宽度、高度和透明度

3、在一个元素使用hide()方法时会记录原先的display属性,当调用show()方法的时候会根据hide()方法记住的display属性值来显示该元素

4、show()方法和hide()方法都能接受一个参数,表示运动的快慢

$('.div1').toggle(function(){
$('.div2').hide(600);
 },function(){
  $('.div2').show(600);
 });

fadeIn()方法和fadeOut()方法

1、fadeOut()方法在指定的一段时间内只降低元素的不透明度,而fadeIn()方法则相反

2、接受一个参数

 $('.div1').toggle(function(){
  $('.div2').fadeIn(600);
 },function(){
  $('.div2').fadeOut(600);
 });

slideUp()方法和slideDown()方法

 1、slideUp()方法和slideDown()方法只会改变元素的高度。如果一个元素的display属性值为"none",当调用slideDown()方法时,这个元素将由上至下延伸,slideUp()方法相反

 2、接受一个参数

 $('.div1').toggle(function(){
  $(this).next().slideUp();
 },function(){
  $(this).next().slideDown();
 });

自定义动画方法animate()

 语法:animate(params,speed,callback);

 (1)params:一个包含样式属性及值得映射

 (2)speed:速度参数,可选

 (3)callback:在动画完成时执行的函数,可选

1、基本用法

 $('.div1').click(function(){
  $('.div2').animate({width:'+=50px',height:'300px'},600);
 });

2、多重动画

如果要采用链式运动可以采用链式写法

 $('.div1').click(function(){
 $('.div2').animate({width:'350px'},600)
  .animate({height:'300px'},600);
 });

注意:如果采用链式写法时用了css()方法,css()方法不会添加到运动队列中,会直接执行而不等待前面的动画

 $('.div1').click(function(){
  $('.div2').animate({width:'350px'},600)
   .animate({height:'300px'},600)
   .css('border','10px solid black');
 });

这个元素的边框会在一开始就添加到了元素上,要解决这个问题的办法就是使用回调函数

如果要同时运动可将要运动的值写在一起

 $('.div1').click(function(){
 $('.div2').animate({width:'350px',height:'300px'},600);
 });

回调函数

回调函数适用与jQuery所有的动画效果方法

例如要解决链式写法css()属性会直接执行的问题可以采用回调函数的方法

 $('.div1').click(function(){
 $('.div2').animate({width:'350px'},600)
   .animate({height:'300px'},600,function(){
   $('.div2').css('border','10px solid black');
  });
 });

停止动画和判断是否处于动画状态

1、停止元素的动画

stop()方法接受两个参数

第一个参数为true或者false,表示是否要清空为执行完的动画队列,例如我们写链式动画时,如果第一个参数为true,当我们阻止了正在进行的一个动画操作后,后面的动画操作都会被清空,如果参数为false时,就只会阻止当前的这个动画,动画队列后的动画依旧执行

第二个参数为true或者false,表示是否要将正在执行的动画跳转到末状态

2、判断元素是否处于动画状态

如果用户频繁的执行一个animate()动画时,就会出现动画积累,解决方法就是判断元素是否正处于动画状态,如果元素不处于动画状态,才为元素添加新的动画

if(!$('div1').is(':animated')){
 // 添加动画
 }

3、延迟动画

如果要延迟执行一个动画,就可以使用delay()方法

 $('.div1').click(function(){
  $('.div2').animate({width:'350px'},600)
   .delay(1000)
   .animate({height:'300px'},600,function(){
    $('.div2').css('border','10px solid black');
   });
 });

其他动画方法

1、slideToggle()方法

通过高度的变化来切换匹配的元素的可见性

$('.div1').click(function(){
 $('.div2').slideToggle();
});

2、fadeTo()方法

可以把元素的不透明度以渐进的方式调整到指定的值,这个动画只调整元素的不透明度

 $('.div1').click(function(){
 $('.div2').fadeTo(600,0.5);
 });

3、fadeToggle()方法

通过不透明度来切换匹配元素的可见性

 $('.div1').click(function(){
 $('.div2').fadeTo(600,0.5);
 });

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# jquery  # 动画方法  # jQuery实现的背景颜色渐变动画效果示例  # jQuery之动画效果大全  # jQuery Ajax 加载数据时异步显示加载动画  # 原生js仿jquery animate动画效果  # jQuery实现图像旋转动画效果  # jQuery中使用animate自定义动画的方法  # 深入理解jquery自定义动画animate()  # jQuery实现点击水纹波动动画  # 基于jquery fly插件实现加入购物车抛物线动画效果  # 利用jquery制作滚动到指定位置触发动画  # jQuery动画效果图片轮播特效  # jQuery动画_动力节点节点Java学院整理  # 链式  # 明度  # 回调  # 不透  # 第一个  # 只会  # 可选  # 清空  # 就会  # 见性  # 都能  # 而不  # 时间内  # 第二个  # 自定义  # 当我们  # 要将  # 在一  # 设置为  # 将由 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  实现点击下箭头变上箭头来回切换的两种方法【推荐】  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  Linux系统命令中tree命令详解  如何在万网自助建站中设置域名及备案?  Python进程池调度策略_任务分发说明【指导】  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  Laravel如何为API编写文档_Laravel API文档生成与维护方法  网页设计与网站制作内容,怎样注册网站?  如何撰写建站申请书?关键要点有哪些?  如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  UC浏览器如何设置启动页 UC浏览器启动页设置方法  如何快速生成凡客建站的专业级图册?  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  Laravel如何处理表单验证?(Requests代码示例)  如何在宝塔面板中创建新站点?  如何快速选择适合个人网站的云服务器配置?  重庆市网站制作公司,重庆招聘网站哪个好?  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  如何快速生成专业多端适配建站电话?  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  如何做网站制作流程,*游戏网站怎么搭建?  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  开心动漫网站制作软件下载,十分开心动画为何停播?  Laravel怎么在Blade中安全地输出原始HTML内容  如何在局域网内绑定自建网站域名?  Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  如何用腾讯建站主机快速创建免费网站?  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  原生JS实现图片轮播切换效果  Laravel如何实现一对一模型关联?(Eloquent示例)  Android GridView 滑动条设置一直显示状态(推荐)  北京专业网站制作设计师招聘,北京白云观官方网站?  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  Laravel如何与Pusher实现实时通信?(WebSocket示例)  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  Windows10如何更改计算机工作组_Win10系统属性修改Workgroup  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  Laravel如何使用Collections进行数据处理?(实用方法示例)  Python自动化办公教程_ExcelWordPDF批量处理案例  制作企业网站建设方案,怎样建设一个公司网站?  如何在宝塔面板创建新站点?  Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑