- 浏览: 137602 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
gezi2213:
...
HttpClient及有关jar包详解 -
sailor119:
学习一下!
〖ExtJS〗之ToolBar
本文来自:曹胜欢博客专栏。转载请注明出处: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 还单独提供了只有滑动效果的相关函数 .
名称 |
说明 |
举例 |
通过高度变化(向下增大)来动态地显示所有匹配的元素,在显示完成后可选地触发一个回调函数。 这个动画效果只调整元素的高度,可以使匹配的元素以 “ 滑动 ” 的方式显示出来。在 jQuery 1.3 中,上下的 padding 和 margin 也会有动画,效果更流畅。 |
用 600 毫秒缓慢的将段落滑下 : $("p").slideDown("slow"); |
|
通过高度变化(向上减小)来动态地隐藏所有匹配的元素,在隐藏完成后可选地触发一个回调函数。 |
用 600 毫秒缓慢的将段落滑上 : $("p").slideUp("slow"); |
|
通过高度变化来切换所有匹配元素的可见性,并在切换完成后可选地触发一个回调函数。 |
用 600 毫秒缓慢的将段落滑上或滑下 : $("p").slideToggle("slow"); |
说明:
slideDown 就是 show 的滑动效果版本 , slideUp 就是 hide 的滑动效果版本 , slideToggle 就是 toggle 的滑动效果版本 .
参数完全相同 :
$("#divPop").slideDown(200);
$("#divPop").slideUp("fast");
$("#divPop").slideToggle("slow");
三 . 淡入淡出动画函数
淡出淡出函数只提供透明度渐变的效果 .
名称 |
说明 |
举例 |
通过不透明度的变化来实现所有匹配元素的淡入效果,并在动画完成后可选地触发一个回调函数。 这个动画只调整元素的不透明度,也就是说所有匹配的元素的高度和宽度不会发生变化。 |
用 600 毫秒缓慢的将段落淡入 : $("p").fadeIn("slow"); |
|
通过不透明度的变化来实现所有匹配元素的淡出效果,并在动画完成后可选地触发一个回调函数。 |
用 600 毫秒缓慢的将段落淡出 : $("p").fadeOut("slow"); |
|
把所有匹配元素的不透明度以渐进方式调整到指定的不透明度,并在动画完成后可选地触发一个回调函数。 |
用 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中的ajax详解
2012-07-21 10:32 747Ajax让用户页面丰富起来 , 增 ... -
Java程序员从笨鸟到菜鸟之(九十)跟我学jquery(六)jquery中事件详解
2012-07-24 08:13 836由于jquery本身就是 web 客户端的有力帮手, ... -
Java程序员从笨鸟到菜鸟之(九十二)深入java虚拟机(一)——java虚拟机底层结构详解
2012-09-03 11:27 644本文来自:曹胜欢博客专栏。转载请注明出处:http://b ... -
Java程序员从笨鸟到菜鸟之(九十三)深入java虚拟机(二)——类的生命周期(上)类的加载和连接
2012-09-05 10:30 657本文来自:曹胜欢 ... -
Java程序员从笨鸟到菜鸟之(九十四)深入java虚拟机(三)——类的生命周期(下)类的初始化
2012-09-08 15:00 567上接深入java 虚拟机 —— 深入 ... -
Java程序员从笨鸟到菜鸟之(九十五)深入java虚拟机(四)——java虚拟机的垃圾回收机制
2012-10-06 10:11 725Java语言从出现 ... -
Java程序员从笨鸟到菜鸟之(九十六)深入java虚拟机(五)——java本地接口JNI详解
2012-10-12 09:25 632对于java程序员来说, java 语 ... -
Java程序员从笨鸟到菜鸟之(九十七)深入java虚拟机(六)——类加载的父亲委托机制
2012-10-16 12:11 628在前面两篇博客中我们简单介绍了类加载器 ... -
Java程序员从笨鸟到菜鸟之(九十八)深入java虚拟机(七)深入源码看java类加载器ClassLoader
2012-10-19 11:34 667欢迎阅读本专题的其 ... -
Java程序员从笨鸟到菜鸟之(九十九)深入java虚拟机(八)开发自己的类加载器
2012-10-22 09:26 754欢迎阅读本专题的其他博客: ... -
Java程序员从笨鸟到菜鸟之(一百)sql注入攻击详解(一)sql注入原理详解
2012-10-24 08:00 742前段时间,在很多博客和微博中暴漏出了123 ... -
Java程序员从笨鸟到菜鸟之(一百零一)sql注入攻击详解(二)sql注入过程详解
2012-10-25 10:12 763在上篇博客中 ...
相关推荐
Umi-OCR-main.zip
基于springboot+Web的毕业设计选题系统源码数据库文档.zip
基于springboot校外兼职教师考勤管理系统源码数据库文档.zip
58商铺全新UI试客试用平台网站源码
基于springboot大学生就业信息管理系统源码数据库文档.zip
基于SpringBoot的口腔诊所系统源码数据库文档.zip
数据存放网盘,txt文件内包含下载链接及提取码,永久有效。失效会第一时间进行补充。样例数据及详细介绍参见文章:https://blog.csdn.net/T0620514/article/details/143956923
3-240P2162218.zip
网络安全 基于Qt创建的Linux系统下的浏览器.zip
C++ 类和对象:多态-练习题目2(制作咖啡和茶叶)
基于springboot+J2EE在线项目管理与任务分配中的应用源码数据库文档.zip
简介本项目提供了一个在51单片机上运行的简单操作系统,旨在帮助学习者深入理解操作系统的基本原理和任务调度机制。该操作系统通过汇编和C语言编写,实现了任务调度、中断处理等核心功能,并提供了详细的源代码和注释,方便学习和实践。
本文将深度卷积神经网络(CNN)设计实现一个复杂结构的生成模型,旨在通过多阶段的编码器-解码器结构,能够有效地将灰度图像转换为彩色图像。最后,本文将实现一个简单的Web应用,用户可以通过上传灰度图像,应用会使用预训练的Caffe模型对其进行颜色化,并将结果返回给用户。 1.模型设计:模型由多个卷积层、ReLU激活函数和批归一化层组成,通过前向传播函数将输入的灰度图像(L通道)转换为彩色图像(ab通道)。如果指定了 pretrained=True,则会自动下载并加载预训练的模型权重。 2. 系统通过Flask框架提供了一个Web应用,用户可以上传灰度图像,系统会自动将其转换为彩色图像,并在网页上显示结果。整个过程包括文件验证、图像处理、颜色化预测和结果展示,具有较高的实用性和用户体验。
一个JAVA图形化的、联网的五子棋游戏.zip javaweb
KWDB 是一款面向 【AIoT 场景】的【分布式多模数据库】,支持在同一实例同时建立时序库和关系库并融合处理多模数据,具备千万级设备接入、百万级数据秒级写入、亿级数据秒级读取等时序数据高效处理能力,具有稳定安全、高可用、易运维等特点。
页面数量:7页 网页主题:网站模板、酒店网站模板、官方网站模板 网页页面:首页、关于我们、相关服务、服务详情、在线博客、博客详情、在线留言 页面实现元素:加载动画、滚动加载、主题切换、导航栏 、轮播图、图文列表、图片切换、 文字列表、 按钮悬停、图片悬停、表单 实现技术:HTML、CSS 、JQuery 源码样式及js文件均分开存放,所有内容仅供初学者学习参考
内容概要:本文档提供了详细的 Neo4j 安装与配置指南,涵盖 Windows、Linux 和 Mac 系统的安装步骤。具体包括下载、安装、启动服务、修改配置文件(如端口配置、远程访问和内存限制)、设置管理员密码以及基本的 Cypher 查询语言使用方法。同时,还提供了一些常见问题及其解决方案。 适合人群:数据库管理员、软件开发人员、系统管理员。 使用场景及目标:①帮助初学者快速掌握 Neo4j 的安装与配置;②适用于需要搭建和使用图数据库的项目;③为已有用户解决常见问题。 其他说明:本文档不仅包含了基础的安装和配置流程,还提供了实际操作中可能遇到的问题及其解决方法,有助于提高使用者的实际操作能力。
基于SpringBoot+Vue的软件产品展示销售系统源码数据库文档.zip
《书戴嵩画牛》教学课件.pptx
20届智能车 【项目资源】:包含前端、后端、移动开发、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源,毕业设计等各种技术项目的源码。包括C++、Java、python、web、C#、EDA等项目的源码。 【适用人群】:适用于希望学习不同技术领域的初学者或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。