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 相关文章推荐
js树形控件脚本代码
Jul 24 Javascript
jsTree 基于JQuery的排序节点 Bug
Jul 26 Javascript
Jquery实现自定义弹窗示例
Mar 12 Javascript
JavaScript中跨域调用Flash的方法
Aug 11 Javascript
jQuery遍历json中多个map的方法
Feb 12 Javascript
Javascript中Array用法实例分析
Jun 13 Javascript
SpringMVC restful 注解之@RequestBody进行json与object转换
Dec 10 Javascript
jQuery实现可拖拽的许愿墙效果【附demo源码下载】
Sep 14 Javascript
Vue服务端渲染和Vue浏览器端渲染的性能对比(实例PK )
Mar 31 Javascript
vue单页应用加百度统计代码(亲测有效)
Jan 31 Javascript
详解在Vue中使用TypeScript的一些思考(实践)
Jul 06 Javascript
vue中 this.$set的用法详解
Sep 06 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和Mysqlweb应用开发核心技术-第1部分 Php基础-2 php语言介绍
2011/07/03 PHP
PHP7多线程搭建教程
2017/04/21 PHP
ajax+php实现无刷新验证手机号的实例
2017/12/22 PHP
Javascript 中文字符串处理额外注意事项
2009/11/15 Javascript
div+css布局的图片连续滚动js实现代码
2010/05/04 Javascript
最原始的jQuery注册验证方式
2016/10/11 Javascript
Angularjs通过指令监听ng-repeat渲染完成后执行脚本的方法
2016/12/31 Javascript
React-router 4 按需加载的实现方式及原理详解
2017/05/25 Javascript
详谈js中标准for循环与foreach(for in)的区别
2017/11/02 Javascript
解决Vue使用mint-ui loadmore实现上拉加载与下拉刷新出现一个页面使用多个上拉加载后冲突问题
2017/11/07 Javascript
详解JavaScript中的坐标和距离
2019/05/27 Javascript
JS控制只能输入数字并且最多允许小数点两位
2019/11/24 Javascript
angula中使用iframe点击后不执行变更检测的问题
2020/05/10 Javascript
在Vue中使用HOC模式的实现
2020/08/23 Javascript
jquery插件实现轮播图效果
2020/10/19 jQuery
[13:16]INFAMOUS vs VGJ T BO3
2018/06/07 DOTA
python类继承用法实例分析
2015/05/27 Python
Python中如何获取类属性的列表
2016/12/26 Python
django 创建过滤器的实例详解
2017/08/14 Python
python链接oracle数据库以及数据库的增删改查实例
2018/01/30 Python
Flask框架WTForm表单用法示例
2018/07/20 Python
python爬取网易云音乐评论
2018/11/16 Python
pyshp创建shp点文件的方法
2018/12/31 Python
Python imread、newaxis用法详解
2019/11/04 Python
使用遗传算法求二元函数的最小值
2020/02/11 Python
css3中检验表单的required,focus,valid和invalid样式
2014/02/21 HTML / CSS
中粮集团旗下食品网上购物网站:我买网
2016/09/22 全球购物
高级Java程序员面试题
2016/06/23 面试题
九年级体育教学反思
2014/01/23 职场文书
办公室打字员岗位职责
2014/04/16 职场文书
党支部2014年度工作总结
2014/12/04 职场文书
redis实现共同好友的思路详解
2021/05/26 Redis
Linux系统下MySQL配置主从分离的步骤
2022/03/21 MySQL
frg-100简单操作(设置)说明
2022/04/05 无线电
什么是css原子化,有什么用?
2022/04/24 HTML / CSS
ORACLE中dbms_output.put_line输出问题的解决过程
2022/06/28 Oracle