jQuery 自定义动画——animate

boyanx3个月前技术教程10

自定义动画

使用animate()方法

animate(params,[duration],[easing],[callback])

其中params为希望进行变换的CSS属性列表,以及希望变化到的最终值;

需要特别指出,params中的变量遵循camel(驼峰式)命名方式,例如:paddingLeft不能写成padding_left

params只能是CSS中用数值表示的属性,例如width、top、opacity等,像backgroundColor这样的属性不被animate()支持;

属性值必须加引号,例如:width: "90%",用逗号隔开

duration为持续的时间,三种预定速度之一的字符串("slow","normal", or "fast")或表示动画时长的毫秒数值(如:1000)

fast: 快速的

easing为可选参数,通常供动画插件使用,用来控制变化工程的节奏,jQuery中只提供了linear和swing两个值

jQuery 代码:

点击按钮后div元素的几个不同属性一同变化

// 在一个动画中同时应用三种类型的效果

$("#go").click(function(){
    $("#block").animate({
        width:"90%",
        height:"100%",
        fontSize:"10em",
        borderWidth:"10px"
    }, 1000 );
});

HTML 代码:


Hello!

相对变化的自定义动画

在params的CSS属性列表中,jQuery还允许使用"+="或者"-="来表示相对变化(多次变化)



animate()方法

<script language="javascript" src="jquery.min.js"></script>
<script language="javascript">
$(function(){
    $("input:first").click(function(){
    $("#block").animate({
    left: "-=80px" //相对左移
    },300);
    });
    $("input:last").click(function(){
    $("#block").animate({
    left: "+=80px" //相对右移
    },300);
    });
});
</script>


 

让指定元素左右移动

jQuery 代码:

$("#right").click(function(){
$(".block").animate({left: '+50px'}, "slow"); //+50px只能移动一次
});
$("#left").click(function(){
$(".block").animate({left: '-50px'}, "slow"); //-50px只能移动一次
});

HTML 代码:

 

另外在CSS属性列表params中,还可以将属性的最终值设置为"show"、"hide"、"toggle"

在600毫秒内切换段落的高度和透明度

jQuery 代码:

$("p").animate({
height: 'toggle', opacity: 'toggle'
}, "slow");


用500毫秒将段落移到left为50的地方并且完全清晰显示出来(透明度为1)

jQuery 代码:

$("p").animate({
left: 50, opacity: 'show'
}, 500);


一个使用"easein"函数提供不同动画样式的例子。只有使用了插件来提供这个"easein"函数,这个参数才起作用。

jQuery 代码:

$("p").animate({
opacity: 'show'
}, "slow", "easein");


animate()方法还有另外一种形式

animate(params,options)

其中params与第一种形式完全相同,options为动画的可选参数列表,主要包括duration、easing、callback、queue等。

其中duration、easing、callback与第1种形式完全一样,queue为布尔值,表示当有多个animate()组成jQuery链时,当前

animate()与紧接着的下一个animate()是按顺序执行(true,默认值),还是同时触发(false);

动画效果的触发程序

jQuery代码:

$(function(){
    $("input:eq(0)").click(function(){
    //第一个animate与第二个animate同时执行,然后再执行第三个
    $("#block1").animate({width:"90%"},{queue:false,duration:1500})
    .animate({fontSize:"24px"},1000)
    .animate({borderRightWidth:"20px"},1000);
    });
    $("input:eq(1)").click(function(){
    //依次执行三个animate
    $("#block2").animate({width:"90%"},1500)
    .animate({fontSize:"24px"}, 1000)
    .animate({borderRightWidth:"20px"}, 1000);
    });
    $("input:eq(2)").click(function(){
    $("input:eq(0)").click(); //触发单击事件,等同于$("input:eq(0)").trigger("click");
    $("input:eq(1)").click(); //触发单击事件,等同于$("input:eq(1)").trigger("click");
    });
    $("input:eq(3)").click(function(){
    //恢复默认设置
    $("div").css({width:"", fontSize:"", borderWidth:""});
    });
});

HTML代码:





Block1
Block2

delay(duration,[queueName])

设置一个延时来推迟执行队列中之后的项目。

jQuery代码:

$("button").click(function(){
//$("li").animate(参与过渡的属性,时长,效果,回调函数);
$("li").delay(5000).animate({
"width": "500px"
});
})

HTML代码:


  • 1111

实例: delay特效







Document




<script src="js/jquery-2.2.4.js" type="text/javascript" charset="utf-8"></script> <script src="js/jquery-ui.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript"> var str = ""; for(var i=0;i<10;i++){ for(var j=0;j<10;j++){ str j50pxtop: i50pxbackground-position: j-50px i-50px>"; } } $("ul").html(str); $("button").click(function(){ //$("li").delay(Math.random()*1000).show() $("li").each(function(){ $(this).delay(Math.random()*1000).fadeIn(100,"easeInOutBounce"); }) }) </script>

页面滚动到顶部的效果

$('html, body').animate({scrollTop:0}, 500); //页面滚动

实例: 返回顶部









返回
顶部
<script src="js/jquery-2.2.4.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript"> $("a").click(function(){ //返回顶部特定写法 $("html,body").animate({ "scrollTop": 0 }) }); </script>
标签: jquery 特效

相关文章

零基础开始学 Web 前端开发,有什么建议?(附视频教程)

WEB前端看似简单,其实不然,要学的知识点很多很杂,对于零基础学习前端的小伙伴来说,一份详细的前端学习知识点大纲尤为重要。下面,话不多说,直接上干货(全网最全,没有之一)。PS:文末有福利(全阶段视频...

CSS 3.0+HTML5.0制作各种网页特效

1、C33实现点击图片渐渐放大特效 2、CSS3实现图片全屏背景特效 3、CSS3实现的鼠标移动到图片上不规则放大 3、jQuery+CSS3模拟苹果桌面系统 4、CSS3+jQuery 照片...

jQuery.ZoomLoad.js 仅1.5k

这是头一次开发jQuery插件。因为切图网的原因,本人一直在于网页前端开发打交道,jQuery写了多少行特效已经无法统计了,jQuery幻灯片,图片滚动,select,radio,checkbox美化...

太原网页设计培训实战班

在太原学习网页设计培训就到博飞 Fireworks软件讲解色彩与构图的基本概念,并结合不同风格、类型的网页进行案例分析。相关企业网站案例训练,掌握网页界面UI设计的配色,网页中常见元素的表现,包括网...

极客标签前端特效资源精品大荟萃#001

1.前端树形图 -- zTree -- jQuery 树插件这里使用的数据是直接写在js里的。如果能使用ajax来获取数据,更进一步,如果使用ajax获取选择节点的子节点,那么这个zTree将会更赞~...

前端工程师养成计划 专区

前端工程师必修课本课程从最基本的概念开始讲起,步步深入,带领大家学习HTML、CSS样式基础知识,了解各种常用标签的意义以及基本用法,后半部分讲解CSS样式代码添加,为后面的案例课程打下基础。本课程让...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。