如何简单地用YUI做JavaScript动画


Posted in Javascript onMarch 10, 2007

原文地址:http://www.jackslocum.com/blog/2006/08/24/javascript-animations-with-yahoo-ui-made-easy/

YUI的动画类简直就是一门艺术工作。不像其它的传统的JS库,提供了已经“预设好”的直接可运行的效果,相反,它由开发者做自己喜欢的。在这点,我比较喜欢适当地运行一些动画和变换效果,越多越好。

按照这么地说,也会有个问题。动画API是非常“底层”的工作,而且需要您花时间去弄的,子类的构建函数会又长又??碌摹R虼耍?谏弦环⒉嫉陌姹局? 我把 YAHOO.ext.Element的动画效果尽量简单地调用。其实,在这个网站的大多数效果都是它完成的。

但如果我想做些较复杂的效果,该怎么办?当某个效果完成后,YUI能够以函数的方式提供一个回调(callback).利用Callback你能够将多个效果排队来做出复杂的效果。唯一的问题是,在其函数内,每一步效果的封装好的,这样,代码起来就很复杂可怕了。另外一个问题是,当你同一时内多个元素发生动画效果的话,代码会持续地随着每个元素它拥有的回调函数的增长而增长。不得不说,YahooUI!在这方面,有点难以适用于开发,--尤其日渐常用这类效果。

新版的yui.ext包含了原本yui做动画所需的复杂代码,甚至比你想的要简单。这里是功能列表:

*自动调整动画顺序 --回调函数不再有啦!

* 处理多个元素的动画更方便,--只要设置一下属性。
* 对多个元素的动画效果,自动同步和调整顺序 --只要添加 Actors到一个 Animator 就可以同步。
* 一些常用的预设效果(尽管yui不会引起内存泄漏,但切勿替换、复制script.aculo.us那炫目的效果【 译者frank注:这里是反语,讽刺script.aculo.us会内存泄漏)】
* 允许动画过程中执行任何的函数。
*允许动画过程中调用自动调整的同步函数。

*动画列表(一组的动画效果)可按需预定义和执行

好,让我们看看进入代码部分
以id为example的div新建一个actor对象。第三个参数真告诉它立即开始捕捉动作(否则的话你必须调用startCature()) 如果是false则是一个标准的元素对象,同时执行所有调用。
var exdiv = new YAHOO.ext.Actor('example', null, true);
产生一个从上移动下来的效果:
exdiv.moveIn('top');
播放动画:
exdiv.play();

另外一个范例:
这是范例的目的是在导航上(Jack's Blog)做交换效果
注意: Animators 可以支持一个或以上的元素的排序和同步动画
创建一个animator,包含两个Actor (this.minbar and this.dockbar),然后开始捕捉他们的动作。
var anim = new YAHOO.ext.Animator(this.minbar, this.dockbar); 
anim.startCapture();
开始动画:
this.dockbar.setX(-this.dockedWidth); 
this.dockbar.setWidth(this.dockedWidth); 
this.dockbar.setVisible(true);
beginSync() 告诉 animator 组合每个actions的动作,同时播放这些动画。
anim.beginSync(); 
this.minbar.move('left', this.minbar.getWidth()+this.margin, true, .35); 
this.dockbar.move('right', this.dockedWidth+this.margin, true, .4, null, YAHOO.util.Easing.easeOut); 
anim.endSync();
播放完成后执行这个 callback.
anim.play(this.fireDocked);

更多复杂的例子
Click here to see what it does. Sorry, this depended on an old blog layout and no longer works. I won't go step by step but notice how the code flows like a normal javascript app? You would never know that there are over 10 different asynchronous animations being sequenced. Notice the async calls too - those are calling out to my navbar and telling it to dock or undock, which also performs more animations. The Animator here waits for those animations to complete before continuing. Dont' mind my code spacing, I am big fan of spacing code into logical blocks!2
var animator = new YAHOO.ext.Animator();
var cursor = new YAHOO.ext.Actor('cursor-img', animator);  
var resize = new YAHOO.ext.Actor('resize-img', animator); 
var click = new YAHOO.ext.Actor('click-img', animator);  
var splitter = new YAHOO.ext.Actor('splitter', animator);   
animator.startCapture();  
animator.addAsyncCall(Blog.navbar.undockDelegate, 1);  
cursor.show();  
cursor.moveTo(500,400);  
cursor.moveTo(20, getEl('navbar').getY()+10, true, .75); 
click.clearOpacity(); 
click.show();  
click.alignTo(cursor, 'tl', [-4, -4]); 
animator.pause(.5);  
click.hide(true, .7);    
animator.addAsyncCall(Blog.navbar.dockDelegate, 1);    
cursor.alignTo('splitter', 'tr', [0, +100], true, 1); 
resize.alignTo('splitter', 'tr', [-12, +100]);
animator.beginSync(); 
cursor.hide();  
resize.show();  
animator.endSync();  
splitter.highlight('#EEEEFF', '#C3DAF9', .3); 
splitter.highlight('#EEEEFF', '#C3DAF9', .3); 
animator.pause(2);
resize.hide(); 
cursor.show(); 
cursor.moveTo(-100, -100, true);   
animator.stopCapture();  
animator.play();
如果你喜欢做动画,那你一定会爱上yui,特别是现在做动画更容易了。
注意: 这些功能同样包含在 YAHOO.ext.UpdateManager里面. 这是一个使用YAHOO.util.Connect 来AJAX更新元素的简单API ,基于事件驱动使得YAHOO.util.Connect 代码更简洁。 最好的是,你亲自去看看内部的代码因为我现在实在太累了-不能再写BLOGL了!
Javascript 相关文章推荐
一款JavaScript压缩工具:X2JSCompactor
Jun 13 Javascript
Javascript 验证上传图片大小[客户端]
Aug 01 Javascript
js 剪切板的用法(clipboardData.setData)与js match函数介绍
Nov 19 Javascript
在JS数组特定索引处指定位置插入元素的技巧
Aug 24 Javascript
微信小程序开发入门基础教程
Apr 19 Javascript
详解Vue.use自定义自己的全局组件
Jun 14 Javascript
ReactNative实现Toast的示例
Dec 31 Javascript
浅谈Node.js 中间件模式
Jun 12 Javascript
node中的cookie的具体使用
Sep 13 Javascript
解决微信小程序防止无法回到主页的问题
Sep 28 Javascript
VUE2.0 ElementUI2.0表格el-table自适应高度的实现方法
Nov 28 Javascript
小程序角标的添加及绑定购物车数量进行实时更新的实现代码
Dec 07 Javascript
可缩放Reloaded-一个针对可缩放元素的复用组件
Mar 10 #Javascript
为Yahoo! UI Extensions Grid增加内置的可编辑器
Mar 10 #Javascript
Gird事件机制初级读本
Mar 10 #Javascript
Gird组件 Part-3:范例RSSFeed Viewer
Mar 10 #Javascript
对YUI扩展的Gird组件 Part-2
Mar 10 #Javascript
对YUI扩展的Gird组件 Part-1
Mar 10 #Javascript
学习YUI.Ext第七日-View&JSONView Part Two-一个画室网站的案例
Mar 10 #Javascript
You might like
《PHP编程最快明白》第五讲:php目录、文件操作
2010/11/01 PHP
探讨:使用XMLSerialize 序列化与反序列化
2013/06/08 PHP
JavaScript Cookie的读取和写入函数
2009/12/08 Javascript
基于JQuery的多标签实现代码
2012/09/19 Javascript
jQuery中removeClass()方法用法实例
2015/01/05 Javascript
微信小程序之picker日期和时间选择器
2017/02/09 Javascript
VUE element-ui 写个复用Table组件的示例代码
2017/11/18 Javascript
vue-cli项目无法用本机IP访问的解决方法
2018/09/20 Javascript
深入分析element ScrollBar滚动组件源码
2019/01/22 Javascript
vue自定义指令实现方法详解
2019/02/11 Javascript
详解vue-cli3多环境打包配置
2019/03/28 Javascript
Node.JS用纯JavaScript生成图片或滑块式验证码功能
2019/09/12 Javascript
浅谈bootstrap layer.open中end的使用方法
2019/09/12 Javascript
解决ele ui 表格表头太长问题的实现
2019/11/13 Javascript
[56:20]LGD vs VP Supermajor 败者组决赛 BO3 第三场 6.10
2018/07/04 DOTA
Python使用turtule画五角星的方法
2015/07/09 Python
Python第三方库xlrd/xlwt的安装与读写Excel表格
2017/01/21 Python
深入理解Python单元测试unittest的使用示例
2017/11/18 Python
Python利用splinter实现浏览器自动化操作方法
2018/05/11 Python
在win64上使用bypy进行百度网盘文件上传功能
2020/01/02 Python
Python django框架开发发布会签到系统(web开发)
2020/02/12 Python
浅谈ROC曲线的最佳阈值如何选取
2020/02/28 Python
Vilebrequin欧洲官网:法国豪华泳装品牌(男士沙滩裤)
2018/04/14 全球购物
英国首屈一指的票务公司:See Tickets
2019/05/11 全球购物
美国摩托车头盔、零件、齿轮及配件商店:Cycle Gear
2019/06/12 全球购物
Prototype如何更新局部页面
2013/03/03 面试题
高中生校园生活自我评价
2013/09/19 职场文书
计算机网络专业个人的自我评价
2013/10/17 职场文书
自我评价的范文
2014/02/02 职场文书
婚礼主持词
2014/03/13 职场文书
兵马俑的导游词
2015/02/02 职场文书
2016新年问候语大全
2015/11/11 职场文书
2016母亲节感恩话语
2015/12/09 职场文书
2019年中,最受大众欢迎的6本新书
2019/08/07 职场文书
创业计划书之暑假培训班
2019/11/09 职场文书
一看就懂的MySQL的聚簇索引及聚簇索引是如何长高的
2021/05/25 MySQL