jQuery中animate的几种用法与注意事项


Posted in Javascript onDecember 12, 2016

一、animate语法结构

animate(params,speed,callback)

params:一个包含样式属性及值的映射,比如{key1:value1,key2:value2}

speed:速度参数[可选]

callback:在动画完成时执行的函数[可选]

二、自定义简单动画

用一个简单例子来说明,实现单击某div在页面上横向飘动的效果。

<style>
 #cube{
  position:relative;/* 不加这句元素不能动 */
  width:30px;
  height:30px;
  background:red;
  cursor:pointer;
 }
</style>
<body>
 <div>
  <div id="cube"></div>
 </div>
 <script>
  $(function(){
   $("#cube").click(function(){
    $(this).animate({left:"100px"},2000)
   })
  })
 </script>

为了使元素动起来,要改变left属性。为了能影响元素top、right、bottom、left属性值必须声明元素的position。

jQuery中animate的几种用法与注意事项
演示效果

三、累加、累减动画

在之前的代码中,设置了{left:"100px"}这个属性作为参数,如果改写为{left:"+=25px"} ,效果如下

jQuery中animate的几种用法与注意事项
演示效果

四、多重动画

同时执行多个动画

上面的例子是一个很简单的动画。如果想同时执行多个动画,比如在元素向右滑动的同时,放大元素高度。

代码如下:

$(this).animate({left:"+=25px",height:"+=20px"},1000)

jQuery中animate的几种用法与注意事项

演示效果

五、按顺序执行多个动画

上例中,向右滑动与高度变大是同时发生的,如果想让方块先向右滑动再变高,只需将代码拆分

如下:

$(this).animate({left:"+=25px"},500)
  .animate({height:"+=20px"},500)

像这样的动画效果的执行有先后顺序,称为“动画队列”

jQuery中animate的几种用法与注意事项
演示效果

六、综合示例

单击方块,让他向右移动的同时增高,不透明度从50%增加到100%,之后上下移动,加宽,完成后淡出。

$("#cube").click(function(){
    $(this).animate({left:"100px",height:"100px",opacity:"1"},500)
    .animate({top:"40px",width:"100px"},500)
    .fadeOut('slow')
   })

为同一元素应用多重效果时可以通过链式方式对这些效果进行排队。

jQuery中animate的几种用法与注意事项
演示效果

七、动画回调函数

在上例中,如果想在最后一步切换css样式(background:blue),而不是淡出,如果按照通常处理,相关代码如下:

$("#cube").click(function(){
    $(this).animate({left:"100px",height:"100px",opacity:"1"},500)
    .animate({top:"40px",width:"100px"},500)
    .css("border","5px solid blue")//改动这行
   })

然而,css()方法被提前调用。

jQuery中animate的几种用法与注意事项
演示效果

引起这个问题的原因是,css()方法不会加入到动画队列中,而是立即执行。可以使用回调函数对非动画方法实现排队。

正确的相关代码如下:

$("#cube").click(function(){
    $(this).animate({left:"100px",height:"100px",opacity:"1"},500)
    .animate({top:"40px",width:"100px"},500,function(){
     $(this).css("border","5px solid blue")
    })
   })

jQuery中animate的几种用法与注意事项

演示效果

值得注意的是,callback适用于jquery所有的动画方法,比如slidDown() ,show()等。

总结

以上就是关于jquery中animate的几种用法和注意事项,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
基于Jquery的温度计动画效果
Jun 18 Javascript
jquery插件开发注意事项小结
Jun 04 Javascript
jquery中对于批量deferred的处理方法
Jan 22 Javascript
js原型继承的两种方法对比介绍
Mar 30 Javascript
分享有关jQuery中animate、slide、fade等动画的连续触发、滞后反复执行的bug
Jan 10 Javascript
简单的分页代码js实现
May 17 Javascript
Bootstrap页面标题Page Header的实现方法
Mar 22 Javascript
基于模板引擎Jade的应用(详解)
Dec 12 Javascript
Vue使用watch监听一个对象中的属性的实现方法
May 10 Javascript
vue 项目软键盘回车触发搜索事件
Sep 09 Javascript
Vue用mixin合并重复代码的实现
Nov 27 Vue.js
Element-ui 自带的两种远程搜索(模糊查询)用法讲解
Jan 29 Javascript
Websocket协议详解及简单实例代码
Dec 12 #Javascript
jQuery中值得注意的trigger方法浅析
Dec 12 #Javascript
jQuery实现字符串全部替换的方法
Dec 12 #Javascript
Radio 单选JS动态添加的选项onchange事件无效的解决方法
Dec 12 #Javascript
简单实现jquery焦点图
Dec 12 #Javascript
javascript中setAttribute兼容性用法分析
Dec 12 #Javascript
jQuery焦点图左右转换效果
Dec 12 #Javascript
You might like
关于PHP开发的9条建议
2015/07/27 PHP
php中session_id()函数详细介绍,会话id生成过程及session id长度
2015/09/23 PHP
PDO::quote讲解
2019/01/29 PHP
php伪静态验证码不显示的解决方案
2019/09/26 PHP
几个比较经典常用的jQuery小技巧
2010/03/01 Javascript
js加密解密字符串可自定义密码因子
2014/05/13 Javascript
分享一个自己动手写的jQuery分页插件
2014/08/28 Javascript
轻松创建nodejs服务器(6):作出响应
2014/12/18 NodeJs
Bootstrap Table表格一直加载(load)不了数据的快速解决方法
2016/09/17 Javascript
基于JavaScript实现屏幕滚动效果
2017/01/18 Javascript
Babel 入门教程学习笔记
2018/06/13 Javascript
vue实现后台管理权限系统及顶栏三级菜单显示功能
2019/06/19 Javascript
解决layer 动态加载select 失效的问题
2019/09/18 Javascript
细述Javascript的加法运算符的具体使用
2019/10/18 Javascript
javascript 高级语法之继承的基本使用方法示例
2019/11/11 Javascript
vue-autoui自匹配webapi的UI控件的实现
2020/03/20 Javascript
微信小程序以ssm做后台开发的实现示例
2020/04/08 Javascript
Python抓取Discuz!用户名脚本代码
2013/12/30 Python
详解python tkinter教程-事件绑定
2019/03/28 Python
Python实现带下标索引的遍历操作示例
2019/05/30 Python
Python加密模块的hashlib,hmac模块使用解析
2020/01/02 Python
关于CSS Tooltips(鼠标经过时显示)的效果
2013/04/10 HTML / CSS
Html5原生拖拽相关事件简介以及基础实现
2020/11/19 HTML / CSS
Omio西班牙:全欧洲低价大巴、火车和航班搜索和比价
2017/02/11 全球购物
C++是不是类型安全的
2014/02/18 面试题
毕业生机械建模求职信
2013/10/14 职场文书
业务经理的岗位职责
2013/11/16 职场文书
八年级美术教学反思
2014/02/02 职场文书
报纸媒体创意广告词
2014/03/17 职场文书
生育关怀行动实施方案
2014/03/26 职场文书
学校对教师的评语
2014/04/28 职场文书
打架检讨书
2015/01/27 职场文书
WordPress多语言翻译插件 - WPML使用教程
2021/04/01 PHP
python如何正确使用yield
2021/05/21 Python
详解PHP服务器如何在有限的资源里最大提升并发能力
2021/05/25 PHP
看完这篇文章获得一些java if优化技巧
2021/07/15 Java/Android