Java程序员从笨鸟到菜鸟之(九十一)跟我学jquery(七)jquery动画大体验
本文来自:曹胜欢博客专栏。转载请注明出处:http://blog.csdn.net/csh624366188
最近一直感觉自己好忙,每天都浑浑噩噩的过着,转眼间,好像有好长时间没有更新笨鸟到菜鸟了。现在想想,实在罪过了。自从从北京回来就一直投入不了状态,所以也想利用一下这个写博客的机会来促进自己早日投入状态吧。今天我们要讲的是jQuery动画的东西,其实一说到动画,我相信很多人想到的应该是flash吧。其实不然,现在我们将要用jquery来改变flash的一统天下,当然,我们这里所说的动画和flash所做的动画还是有很大的区别的。所以也谈不上他两个产品有什么竞争关系,下面我们就先通过一个简单的实例来看一下jquery的强大吧。
在很多web开发过程中,我们都会用到弹出层的情况,我们再做弹出层的时候大多数都应该用的js实现把。假设有如下需求:
· 单击图中的"显示提示文字"按钮,在按钮的下方显示一个弹出
· 单击任何空白区域或者弹出层,弹出层消失
用原始JavaScript我们也完全可以完成这个工作. 有以下几点注意事项:
1.弹出层的位置需要动态计算.因为触发弹出事件的对象可能出现在页面的任何位置,比如截图中的位置.
2.为document绑定单击是关闭弹出层的函数,要使用多播委托,否则可能冲掉其他人在document绑定的函数.
3.为document绑定了关闭函数后,需要在显示函数中取消事件冒泡,否则弹出层将显示后立刻关闭
· 下面我们来看一下用jquery来实现这里的弹出层是怎么实现的:
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <title>jQuery – 弹出层动画</title>
- <script type="text/javascript" src="jquery-1.7.2.js"></script>
- <script type="text/javascript">
- $(document).ready(function()
- {
- //动画速度
- var speed = 500;
- //绑定事件处理
- $("#btnShow").click(function(event)
- {
- //取消事件冒泡,所谓事件冒泡就是在子控件触发事件时父控件也触发相应的事件
- event.stopPropagation();
- //获得触发事件控件的位置
- var offset = $(event.target).offset();
- //设置弹出层的位置
- $("#divPop").css({ top: offset.top + $(event.target).height() + "px", left: offset.left });
- //动画显示弹出层
- $("#divPop").show(speed);
- });
- //单击空白区域隐藏弹出层
- $(document).click(function(event) { $("#divPop").hide(speed) });
- //单击弹出层则自身隐藏
- $("#divPop").click(function(event) { $("#divPop").hide(speed) });
- });
- </script>
- </head>
- <body>
- <div>
- <br /><br /><br />
- <button id="btnShow">弹出层</button>
- </div>
- <!-- 弹出层 -->
- <div id="divPop" style="background-color: #f0f0f0; border: solid 1px #000000; position: absolute; display:none;
- width: 300px; height: 100px;">
- <div style="text-align: center;">这里是弹出层</div>
- </div>
- </body>
- </html>
从上边代码的效果我们可以看到,利用jquery除了实现了自动隐藏和弹出层,还实现了动画弹出的效果。这样的效果让我这个初学jquery的小菜确实欢喜。所以说感觉很有必要专门抽出一篇来讲解一下这个jquery动画。Ok,下面我们就一起来正式看一下jquery动画的东西
jQuery的动画函数主要分为三类:
基本动画函数:既有透明度渐变,又有滑动效果. 是最常用的动画效果函数.
滑动动画函数:仅使用滑动渐变效果.
淡入淡出动画函数:仅使用透明度渐变效果.
这三类动画函数效果各不相同,用法基本一致.大家可以自己尝试.另外也许上面的三类函数效果都不是我们想要的,那么jQuery也提供了自定义动画函数,将控制权放在我们手里让我们自己定义动画效果。下面我们就来一一看一下这三种动画函数。
一.基本动画函数:
1、show()
显示隐藏匹配元素。这个就是 'show( speed, [callback] )'无动画的版本。如果选择的元素是可见的,这个方法将不会改变任何东西。无论这个元素是通过hide()方法隐藏的还是在CSS里设置了display:none;,这个方法都将有效。
例如:显示所有段落,$("p").show()
2、show(speed,[callback])
以优雅的动画显示匹配的元素,并且在显示完成后可选择返回一个回调函。可根据指定的速度动态改变每个匹配元素高度、宽度和不透明度。
例如:用缓慢的动画将隐藏的段落显示出来,历时600毫秒,$("p").show(600)
3、hide()
隐藏显示元素。这个就是 'hide( speed, [callback] )'的无动画版。如果选择的元素是隐藏的,这个方法将不会改变任何东西。
例如:隐藏所有段落,$("p").hide()
4、hide(speed,[callback])
以优雅的动画隐藏所有匹配的元素,并在显示完成后可选的触发一个回调函数。可以根据指定的速度动态地改变每个匹配元素的高度、宽度和不透明度。在jQuery 1.3中,padding和margin也会有动画,效果更流畅。
例如:用600ms的时间将段落缓慢的隐藏,$("p").hide("slow");
5、toggle
切换元素的可见状态。如果元素时可见的,切换为隐藏的;如果元素是隐藏的,切换为可见的。
例如:切换所有段落的可见状态,$("p").toggle()
6、toggle(switch)
根据switch参数切花元素的可见状态(true为可见,false为隐藏)。如果switch设为true,则调用show()方法来显示匹配的元素,如果switch设为false则调用hide()来隐藏元素。
例如:切换所有段落的可见状态,var flip=0;$("button").click(function(){$("p").toggle(flip++%2==0);});
7、toggle(speed,[callback])
以优雅的动画切换所有匹配的元素,并在显示完成后可选的触发一个回调函数。可根据指定的速度动态的改变每个匹配元素的高度、宽度和不透明度。jquery 1.3,padding和margin也会有动画,效果更流畅。
例如:用200ms将段落迅速切换显示状态,之后弹出一个对话框,$("p").toggle("fast",function(){alert("hello !");});
说明:speed参数可以使用三种预定速度之一的字符串("slow", "normal", or "fast")或表示动画时长的毫秒数值(如:1000).
二.滑动动画函数
基本动画函数的效果是一个综合了滑动和透明度渐变的函数, jQuery还单独提供了只有滑动效果的相关函数.
名称 |
说明 |
举例 |
slideDown(speed, [callback]) |
通过高度变化(向下增大)来动态地显示所有匹配的元素,在显示完成后可选地触发一个回调函数。 这个动画效果只调整元素的高度,可以使匹配的元素以“滑动”的方式显示出来。在jQuery 1.3中,上下的padding和margin也会有动画,效果更流畅。 |
用600毫秒缓慢的将段落滑下: $("p").slideDown("slow"); |
slideUp(speed, [callback]) |
通过高度变化(向上减小)来动态地隐藏所有匹配的元素,在隐藏完成后可选地触发一个回调函数。 |
用600毫秒缓慢的将段落滑上: $("p").slideUp("slow"); |
slideToggle(speed, [callback]) |
通过高度变化来切换所有匹配元素的可见性,并在切换完成后可选地触发一个回调函数。 |
用600毫秒缓慢的将段落滑上或滑下: $("p").slideToggle("slow"); |
说明:
slideDown就是show的滑动效果版本, slideUp就是hide的滑动效果版本, slideToggle就是toggle的滑动效果版本.
参数完全相同:
$("#divPop").slideDown(200);
$("#divPop").slideUp("fast");
$("#divPop").slideToggle("slow");
三.淡入淡出动画函数
淡出淡出函数只提供透明度渐变的效果.
名称 |
说明 |
举例 |
fadeIn( speed, [callback] ) |
通过不透明度的变化来实现所有匹配元素的淡入效果,并在动画完成后可选地触发一个回调函数。 这个动画只调整元素的不透明度,也就是说所有匹配的元素的高度和宽度不会发生变化。 |
用600毫秒缓慢的将段落淡入: $("p").fadeIn("slow"); |
fadeOut( speed, [callback] ) |
通过不透明度的变化来实现所有匹配元素的淡出效果,并在动画完成后可选地触发一个回调函数。 |
用600毫秒缓慢的将段落淡出: $("p").fadeOut("slow"); |
fadeTo(speed, opacity, [callback]) |
把所有匹配元素的不透明度以渐进方式调整到指定的不透明度,并在动画完成后可选地触发一个回调函数。 |
用600毫秒缓慢的将段落的透明度调整到0.66,大约2/3的可见度: $("p").fadeTo("slow", 0.66);$("p").fadeTo("slow", |
四、自定义动画函数Custom
1、animate(params,[duration],[easing],[callback])用于创建自定义动画的函数。这个函数的关键在于制定动画形式及结果样式属性对象。这个对象中每个属性都表示一个可以变化的样式属性(如height、top或opacity)。注意:所有指定的属性必须用骆驼形式,比如用marginLeft代替margin-left。而每个属性的值表示这个样式属性到多少是动画结束。如果是一个数值,样式属性就会从当前的值渐变到指定的值。如果使用的是hide、show、toggle这样的字符串值,则会就该属性调用默认的动画形式。
例如:点击按钮后div元素的几个不同属性一同变化,
- $("#go").click(function(){
- $("#block").animate({
- width:"90%",height:"100%",fontSize:"10em",borderWidth:10
- },1000);
- });
2、stop([clearQueue],[gotoEnd])
停止所有在指定元素上正在运行的动画。如果队列中有等待执行的动画(并且clearQueue没有设为true),他们将被马上执行clearQueue(Boolean):如果设置成true,则清空队列。可以立即结束动画。gotoEnd (Boolean):让当前正在执行的动画立即完成,并且重设show和hide的原始样式,调用回调函数等。
例如:点击Go之后开始动画,点Stop之后会在当前位置停下来:
- //开始动画
- $("#go").click(function(){
- $(".block").animate({left: '+200px'}, 5000);
- });
- //当点击按钮后停止动画
- $("#stop").click(function(){
- $(".block").stop();
- });
Java程序员从笨鸟到菜鸟之(九十一)跟我学jquery(七)jquery动画大体验相关推荐
- Java程序员从笨鸟到菜鸟之(五)java开发常用类(包装,数字处理集合等)(下)...
本文来自:曹胜欢博客专栏.转载请注明出处:http://blog.csdn.net/csh624366188 写在前面:由于前天项目老师建设局的项目快到验收阶段,所以,前天晚上通宵,昨天睡了大半天, ...
- Java程序员从笨鸟到菜鸟之(一百零九)一步一步学习webservice(三)开发第一个基于XFire的webservice
在日常开发中,常用的webservice引擎主要有Axis,axis2,Xfire以及cxf(Xfire的升级版).现在只有axis2和cxf官方有更新.今天我们先以一个比较老的引擎为例.来讲诉一下w ...
- Java程序员从笨鸟到菜鸟之(一百零八)一步一步学习webservice(二)webservice基本原理
本来这第二篇打算讲解"开发第一个基于XFire的webservice"的内容来着.但是想想.开发实例只是局限于了会用的层面上.如果想真正的理解webservice还是需要挖掘其原理 ...
- Java程序员从笨鸟到菜鸟之(五)java开发常用类(包装,数字处理集合等)(下)
写在前面:由于前天项目老师建设局的项目快到验收阶段,所以,前天晚上通宵,昨天睡了大半天,下午我们宿舍聚会,所以时间有点耽误,希望大家见谅 上接: Java程序员从笨鸟到菜鸟之(四)java开发常用类( ...
- Java程序员从笨鸟到菜鸟之(一百零六)java操作office和pdf文件(四)页面列表导出cvs,excel、pdf报表.
在平常的开发中我们常常遇到不仅仅只是导出excel报表的情况.有时候也需要导出pdf或者CSV报表.其实原理都差不多.刚开始本来不打算也这篇博客介绍这个的.感觉这篇博客和前面的博客有点雷同.原理基本都 ...
- Java程序员从笨鸟到菜鸟全部博客目录
本文来自:曹胜欢博客专栏.转载请注明出处:http://blog.csdn.NET/csh624366188 欢迎关注微信账号:java那些事:csh624366188.每天一篇java相关的文章 大 ...
- Java程序员从笨鸟到菜鸟之(一百零四)java操作office和pdf文件(二)利用POI实现数据导出excel报表...
在上一篇博客中,我们简单介绍了java读取word,excel和pdf文档内容 ,但在实际开发中,我们用到最多的是把数据库中数据导出excel报表形式.不仅仅简单的读取office中的数据.尤其是在生 ...
- Java程序员从笨鸟到菜鸟之(序言)+全部链接
http://blog.csdn.net/csh624366188 大学上了一年半,接触java也一年半了,虽然中间也有其他东西的学习,但是还是以java为主路线,想想这一年半,除去前半年几乎全玩了, ...
- Java程序员由笨鸟到菜鸟 电子版书正式发布 欢迎大家下载
分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! 欢迎关注 ...
- java程序员从笨鸟到菜鸟_Java程序员从笨鸟到菜鸟之(十四)Html基础积累总结(上)...
[新朋友]点击标题下面(↑)蓝色字"Java那些事"关注 [老朋友]点击右上角,转发或分享本页面内容 这是我以前写的<java程序员由笨鸟到菜鸟>系列博客,每天更新一篇 ...
最新文章
- matlab腐蚀膨胀代码_(三十二)形态学----膨胀和腐蚀
- mysql function加速_MySQL - 函数(FUNCTION)
- WIN7如何替换开机登录画面
- 聚类(1)——混合高斯模型 Gaussian Mixture Model
- java compareTo() 用法注意点
- centos 6安装报错
- 使用croc命令在Linux系统电脑之间传输文件和文件夹
- rsync配置和使用
- Siri为什么越来越蠢?
- 隐马尔可夫的知识要点
- CV经典入门教程:《计算机视觉:算法与应用》第二版
- 多目标启发式算法(NSGA2, MOEA, MOPSO)python实现
- TLSF 内存分配算法详解
- 全球酷站中心 html5网站,除了Behance,还有哪些优质设计资源站
- 电脑端微信多开操作方法
- 《MATLAB 神经网络43个案例分析》:第34章 广义神经网络的聚类算法——网络入侵聚类
- 两种典型频谱仪架构介绍
- 民营企业如何设置绩效考核指标的标准
- 大数据测试指标(一)
- JavaScript基础之基础
热门文章
- Lesson 5.分类模型决策边界与模型评估指标
- 如何利用大数据做金融风控? 原创 2016年11月24日 17:42:03 标签: 大数据 / 金融 / 风控 1594 导语:如何通过海量数据与欺诈风险进行博弈? 随着金融科技、科技金融等概念的
- 思路+步骤+方法,三步教你如何快速构建用户画像?
- php接收流文件,PHP传输文件流及文件流的保存
- Apache Kafka-消费端_批量消费消息的核心参数及功能实现
- 实战SSM_O2O商铺_15【商铺注册】View层+Controller层之图片上传
- Oracle-UNDO表空间解读
- Docker容器导入导出
- Android接收短信-createFromPdu
- matlab里矩阵相除,Matlab中的矩阵除法有问题???