jquery动画,基础以及我发现的新大陆
$.animate()在jquery官方介绍有2中方式,其实我发现的新大陆也是第二种方式的扩展!
一、$.animate( properties [, duration ] [, easing ] [, complete ] )
参数介绍([]包裹的参数可省略)
properties
类型: PlainObject
一个CSS属性和值的对象,动画将根据这组对象移动。
duration (默认:
400)类型: Numberor String
一个字符串或者数字决定动画将运行多久。(注:默认值: "normal", 三种预定速度的字符串("slow", "normal", 或 "fast")或表示动画时长的毫秒数值(如:1000) )
easing (默认:
swing)类型: String
一个字符串,表示过渡使用哪种缓动函数。(注:jQuery自身提供"linear" 和 "swing")。
这个速度函数可以自定义,后面有介绍。
complete
类型: Function()
在动画完成时执行的函数。
举2个例子吧!
示例代码:
$(".btn2").click(function(){
$("#btn2").animate({height:"300px"},2000,'swing',function(){alert('hello world')});
});
示例代码:
$(".btn1").click(function(){
$("#btn1").animate({height:"300px"});
});
二、$.animate( properties, options )
properties
类型: PlainObject
一个CSS属性和值的对象,动画将根据这组对象移动。
- options类型: PlainObject一组包含动画选项的值的集合。 支持的选项:
duration (default:
400)Type: Numberor String
一个字符串或者数字决定动画将运行多久。(愚人码头注:默认值: "normal", 三种预定速度的字符串("slow", "normal", 或 "fast")或表示动画时长的毫秒数值(如:1000) )
easing (default:
swing)Type: String
一个字符串,表示过渡使用哪种缓动函数。(愚人码头注:jQuery自身提供"linear" 和 "swing",其他效果可以使用jQuery Easing Plugin插件)
queue (default:
true)Type: Boolean or String
一个布尔值,指示是否将动画放置在效果队列中。如果为false时,将立即开始动画。 从jQuery1.7开始,队列选项也可以接受一个字符串,在这种情况下,在动画被添加到由该字符串表示的队列中。当一个自定义的队列名称被使用,动画不会自动启动;你必须调用
.dequeue("queuename")来启动它。specialEasing
Type: PlainObject
由此方法的第一个参数properties定义的一个或多个CSS属性,及其相应的缓动函数组成的键值对map。( 1.4 新增)
step
Type: Function( Number now, Tween tween )
每个动画元素的每个动画属性将调用的函数。这个函数为修改Tween 对象提供了一个机会来改变设置中得属性值。
progress
Type: Function( Promiseanimation, Numberprogress, NumberremainingMs )
每一步动画完成后调用的一个函数,无论动画属性有多少,每个动画元素都执行单独的函数。 (version added: 1.8)
complete
Type: Function()
在动画完成时执行的函数。
done
Type: Function( Promiseanimation, BooleanjumpedToEnd )
在动画完成时执行的函数。 (他的Promise对象状态已完成). (version added: 1.8)
fail
Type: Function( Promiseanimation, BooleanjumpedToEnd )
动画失败完成时执行的函数。(他的Promise对象状态未完成)。 (version added: 1.8)
always
Type: Function( Promise animation, Boolean jumpedToEnd )
在动画完成或未完成情况下停止时执行的函数。(他的Promise对象状态已完成或未完成)。 (version added: 1.8)
这里有2个参数的应用要单独说明一下:
Step Function
第二个版本的.animate()提供了一个step选项- 每步动画执行后调用的回调函数。启用自定义动画类型或改变正在执行的动画,此功能是非常有用。它接受两个参数(now 和 fx),this是当前正在执行动画的DOM元素集合。
now: 每一步动画属性的数字值fx:jQuery.fx原型对象的一个引用,其中包含了多项属性,比如elem表示前正在执行动画的元素,start和end分别为动画属性的第一个和最后一个的值,prop为进行中的动画属性。
Easing(缓动)
.animate()还有一个参数是一个字符串命名的使用缓动函数。一个缓动函数指定用于动画进行中在不同点位的速度。 在jQuery库中是默认的时调用 swing。在一个恒定的速度进行动画,请调用 linear. 更多的缓动函数要使用的插件,或者自定义。
直接上代码:
$('#clickme').click(function() {
$('#test').animate({
width: 'toggle',
height: 'toggle'
}, {
duration: 5000,
specialEasing: {
width: 'linear',
height: 'swing'
},
complete: function() {
$(this).after('<div>Animation complete.</div>');
}
});
});
现在新大陆来了!
jQuery.easing = {
linear: function( p ) {
return p;
},
swing: function( p ) {
return 0.5 - Math.cos( p * Math.PI ) / 2;
}
};
这是jquery里animate的Easing源码!如果你觉得就linear和swing不能满足你的要求了,咋们可以扩展一些速度函数。
jQuery.extend(jQuery.easing, {
easeOutBounce: function (x, t, b, c, d) {
console.log(x);//0-1
console.log(t);//0-2500
console.log(b);//0
console.log(c);//1
console.log(d);//2500
// return t/1000;
if ((t /= d) < (1 / 2.75)) {
return c * (7.5625 * t * t) + b;
} else if (t < (2 / 2.75)) {
return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b;
} else if (t < (2.5 / 2.75)) {
return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b;
} else {
return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b;
}
},easeOutCubic: function (x, t, b, c, d) {
return c * ((t = t / d - 1) * t * t + 1) + b;
// return x;
}
})
现在Easing的值就多了2个选择:easeOutBounce和easeOutCubic。(不要问我这算法的问题,呵呵,我也是百度的!)
来,上代码试试看看咯!
$('.new').click(function() {
var ele = $("#new");
ele.css({ "left": "0", "top": "0", "transform": "rotateZ(0deg)" });
$({ left: 0, top: 0, tran: 0 }).animate({
left: 800, top: 180, tran:360
}, {
duration: 2500,
specialEasing: {
left: 'easeOutCubic',
top: 'easeOutBounce'
},
step: function () {
console.log(this.left);
ele.css({ "left": this.left + "px", "top": this.top + "px", "transform": "rotateZ(" + this.tran + "deg)" });
},
complete: function () {
console.log(this.left);
ele.css({ "left": "800px", "top": "180px", "transform": "rotateZ(360deg)" });
}
});
});
这种写法真是第一次见,就忍不住自己试了试,感觉还可以,就想写出来分享给大家!
其实就是自定义了一个动画速度函数!
我把本地的测试效果都移除了,还是把完整代码附给大家试试吧!
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>nick jq animate</title>
</head>
<body >
<button class="reset">重置样式</button>
<div id="btn1" class="nick" style="background-color:aqua;"><button class="btn1">btn1</button></div>
<div id="btn2" class="nick" style="background-color:#eee;"><button class="btn2">btn2</button></div>
<div id="test" class="nick"><button id="clickme">clickme</button><button class="btn2">btn2</button></div>
<div id="new" class="nick" style="width:200px;height:100px;background-color:cadetblue;position:absolute;"><button class="new">clickme</button></div>
<script src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.js"></script>
<script>
$(".btn1").click(function(){
$("#btn1").animate({height:"300px"});
}); $(".btn2").click(function(){
$("#btn2").animate({height:"300px"},2000,'swing',function(){alert('hello world')});
}); $('#clickme').click(function() {
$('#test').animate({
width: 'toggle',
height: 'toggle'
}, {
duration: 3000,
specialEasing: {
width: 'linear',
height: 'swing'
},
complete: function() {
$(this).after('<div>Animation complete.</div>');
}
});
}); $('.new').click(function() {
var ele = $("#new").stop(true, false);
ele.css({ "left": "0", "top": "0", "transform": "rotateZ(0deg)" });
$({ left: 0, top: 0, tran: 0 }).animate({
left: 800, top: 180, tran:360
}, {
duration: 2500,
specialEasing: {
left: 'easeOutCubic',
top: 'easeOutBounce'
},
step: function () {
console.log(this.left);
ele.css({ "left": this.left + "px", "top": this.top + "px", "transform": "rotateZ(" + this.tran + "deg)" });
},
complete: function () {
console.log(this.left);
ele.css({ "left": "800px", "top": "180px", "transform": "rotateZ(360deg)" });
}
});
});
jQuery.extend(jQuery.easing, {
easeOutBounce: function (x, t, b, c, d) {
console.log(x);//0-1
console.log(t);//0-2500
console.log(b);//0
console.log(c);//1
console.log(d);//2500
// return t/1000;
if ((t /= d) < (1 / 2.75)) {
return c * (7.5625 * t * t) + b;
} else if (t < (2 / 2.75)) {
return c * (7.5625 * (t -= (1.5 / 2.75)) * t + .75) + b;
} else if (t < (2.5 / 2.75)) {
return c * (7.5625 * (t -= (2.25 / 2.75)) * t + .9375) + b;
} else {
return c * (7.5625 * (t -= (2.625 / 2.75)) * t + .984375) + b;
}
},easeOutCubic: function (x, t, b, c, d) {
return c * ((t = t / d - 1) * t * t + 1) + b;
// return x;
}
}) $('.reset').click(function(){
$(".nick").css({ height:"" });
});
</script>
</body>
</html>
个人能力有限,只能写到这里了,希望对大家有所帮助,还望大家多多评论,指教!
jquery动画,基础以及我发现的新大陆的更多相关文章
- jquery动画基础
根据id改变字体大小的动画 <div class="speech">样式切换</div> <div id="switcher"&g ...
- 三、jQuery--jQuery基础--jQuery基础课程--第7章 jQuery 动画特效
1.调用show()和hide()方法显示和隐藏元素 show()和hide()方法用于显示或隐藏页面中的元素,它的调用格式分别为:$(selector).hide(speed,[callback]) ...
- jQuery动画特效实例教程
本文以实例形式详细讲述了jQuery动画特效的实现方法. 1.自制折叠内容块 内容块如下: <div class="module"> <div cla ...
- jQuery官方基础教程笔记(转载)
本文转载于阮一峰的博文,内容基础,结构清晰,是jquery入门不可多得的资料,非常好,赞一个. 阮一峰:jQuery官方基础教程笔记 jQuery是目前使用最广泛的javascript函数库. 据统计 ...
- css3动画和jquery动画使用中要注意的问题
前一阵子写demo的时候遇到这样一个问题,就是给元素添加css3或者jquery动画时,在动画结束前不能准确取到元素的css属性. 1. css3动画讨论 先看代码: html: <div id ...
- 炫丽的倒计时效果Canvas绘图与动画基础
前言 想要在自己做的网页中,加入canvas动画效果,但是发现模板各种调整不好,觉得还是要对canvas有所了解,才可以让自己的网页变得狂拽炫酷吊炸天! 一.绘制基础 1 <!DOCTYPE h ...
- jQuery动画使用总结
jQuery动画我用的比较多的仅仅只有show和hide,但是作为一个被我们大多数人所熟知的框架,相信他的动画功能还是比较多样的,这里做个小总结. 1.jQuery animate(),用于创建自定义 ...
- python 全栈开发,Day53(jQuery的介绍,jQuery的选择器,jQuery动画效果)
js总结 js: 1.ECMAScript5 ES5语法 2.DOM CRUD 获取 3种方式 id tag className //面向对象 对象 : 属性和方法 某个对象中 function $( ...
- jQuery 动画效果 与 动画队列
基础效果 .hide([duration ] [,easing ] [,complete ]) 用于隐藏元素,没有参数的时候等同于直接设置 display 属性 $('.target').hide() ...
随机推荐
- gem安装报错解决方法
gem install rdiscount -- --use-system-libraries
- unity3D学习—坦克大战(一)
背景介绍 本人一名C#程序员,从事C#开发已经有四年有余了,目前在一家大型公司上班.鉴于公司的业务需要,现在需要学习unity3D游戏开发,好在unity支持C#脚本开发,无形中省下了许多重新学习新语 ...
- win7 64位下 mongodb安装及命令运行
有网友老催我把框架加上mongodb的支持,于是偶尔抽空看了看相关的文章. 今天有缘,就把mongodb安装了一下,中间遇到了小小的问题,So,把整个过程记录一下: 1:先上官网:http://www ...
- 论如何在手机端web前端实现自定义原生控件的样式
手机开发webapp的同学一定遇到过这样问题,如何为丑极了的手机元素应用自定义的样式.首先,要弄清楚为什么要定义手机原生控件的样式,就需要看看手机的那些原生框样式的丑陋摸样: android: ios ...
- 如何在没有域的环境中搭建AlwaysOn(二)
对DBA而言,不需要域就可以搭建SQL Server AlwaysOn是Windows Server 2016中最令人兴奋的功能了,它不仅可以降低搭建的成本,而且还减少了部署和运维的工作量. 上篇博客 ...
- .NET事件监听机制的局限与扩展
.NET中把“事件”看作一个基本的编程概念,并提供了非常优美的语法支持,对比如下C#和Java代码可以看出两种语言设计思想之间的差异. // C#someButton.Click += OnSomeB ...
- Uiautomator 2.0之Configrator类学习小记
1. Configration类介绍 1.1. Configrator用于设置脚本动作的默认延时 1.2 Configrator功能: 1.2.1 可调节两个模拟动作之间的默认间隔 1.2.2 可调 ...
- 创建分区表和查看分区表的Metadata
未分区的表,只能存储在一个FileGroup中:对table进行分区后,每一个分区都存储在一个FileGroup中.表分区是将逻辑上一个完整的表,按照特定的字段拆分成Partition set,分散到 ...
- TSql 巧用Alt 键
1,查看表的信息 在TSql 编辑器中,选中一个表,如图 点击Alt+F1,就可以查看表的属性定义 2,使用alt批量插入逗号 在Tsql中使用 in 子句,在(value_List)列表中,经常有很 ...
- c#写windows服务
序言 前段时间做一个数据迁移项目,刚开始用B/S架构做的项目,但B/S要寄存在IIs中,而IIs又不稳定因素,如果重启IIs就要打开页面才能运行项目.有不便之处,就改用Windows服务实现.这篇就总 ...