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变换显示图片的实例
Apr 16 Javascript
JQuery实现展开关闭层的方法
Feb 17 Javascript
对JavaScript的全文搜索实现相关度评分的功能的方法
Jun 24 Javascript
用JS实现轮播图效果(二)
Jun 26 Javascript
Mac下使用charles遇到的问题以及解决办法
Jan 10 Javascript
微信小程序 scroll-view隐藏滚动条详解
Jan 16 Javascript
angular.js + require.js构建模块化单页面应用的方法步骤
Jul 19 Javascript
SelectPage v2.4 发布新增纯下拉列表和关闭分页功能
Sep 07 Javascript
Node.js学习之TCP/IP数据通讯(实例讲解)
Oct 11 Javascript
详解vue静态资源打包中的坑与解决方案
Feb 05 Javascript
使用Node.js写一个代码生成器的方法步骤
May 10 Javascript
vue项目支付功能代码详解
Feb 18 Vue.js
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
电脑硬件及电脑配置知识大全
2020/03/17 数码科技
PHP中register_globals参数为OFF和ON的区别(register_globals 使用详解)
2012/02/05 PHP
php使用GD实现颜色渐变实例
2015/06/02 PHP
PHP接口并发测试的方法(推荐)
2016/12/15 PHP
Windows平台实现PHP连接SQL Server2008的方法
2017/07/26 PHP
php7连接MySQL实现简易查询程序的方法
2020/10/13 PHP
jquery中的mouseleave和mouseout的区别 模仿下拉框效果
2012/02/07 Javascript
原生JavaScript实现异步多文件上传
2015/12/02 Javascript
微信公众号-获取用户信息(网页授权获取)实现步骤
2016/10/21 Javascript
jQuery实现下拉菜单的实例代码
2017/06/19 jQuery
Vue单文件组件基础模板小结
2017/08/10 Javascript
JS中关于正则的巧妙操作
2017/08/31 Javascript
zTree获取当前节点的下一级子节点数实例
2017/09/05 Javascript
AngularJS实现图片上传和预览功能的方法分析
2017/11/08 Javascript
用React-Native+Mobx做一个迷你水果商城APP(附源码)
2017/12/25 Javascript
Vue实现点击后文字变色切换方法
2018/02/11 Javascript
详解javascript appendChild()的完整功能
2018/08/18 Javascript
简单了解小程序+node梳理登陆流程
2019/06/24 Javascript
微信小程序和H5页面间相互跳转代码实例
2019/09/19 Javascript
vue 项目打包时样式及背景图片路径找不到的解决方式
2019/11/12 Javascript
微信小程序实现吸顶效果
2020/01/08 Javascript
vue实现购物车案例
2020/05/30 Javascript
解决echarts vue数据更新,视图不更新问题(echarts嵌在vue弹框中)
2020/07/20 Javascript
PyCharm在win10的64位系统安装实例
2017/11/26 Python
Python IDLE入门简介
2017/12/08 Python
Python占用的内存优化教程
2019/07/28 Python
Python matplotlib画曲线例题解析
2020/02/07 Python
matplotlib grid()设置网格线外观的实现
2021/02/22 Python
HTML5+CSS3实现机器猫
2016/10/17 HTML / CSS
Viking Direct爱尔兰:办公用品和家具
2019/11/21 全球购物
解决方案设计综合面试题
2015/08/31 面试题
2014年教师业务学习材料
2014/05/12 职场文书
中华魂演讲稿
2014/05/13 职场文书
酒店工程部主管岗位职责
2015/04/16 职场文书
2016年度优秀辅导员事迹材料
2016/02/26 职场文书
mysql中between的边界,范围说明
2021/06/08 MySQL