dojo 九 effects dojo/_base/fx 和 dojo/fx
官方教程:Dojo Effects
这里讲学习一下dojo如何实现淡入、淡出、滑动等效果。
实现这些特殊的效果有两个包 dojo/_base/fx 和
dojo/fx。
dojo/_base/fx 中提供了一些基础的animation方法,如: animateProperty,
anim, fadeIn, and fadeOut.
dojo/fx
中提供了一些高级的animation方法,如:chain, combine,
wipeIn, wipeOut and
slideTo。
淡入淡出require(["dojo/_base/fx",
"dojo/on", "dojo/dom",
"dojo/domReady!"],
function(fx, on, dom) {
var fadeOutButton =
dom.byId("fadeOutButton"),//淡出按钮 fadeInButton =
dom.byId("fadeInButton"),//淡入按钮 fadeTarget =
dom.byId("fadeTarget");//目标节点 on(fadeOutButton,
"click",
function(evt){ fx.fadeOut({ node: fadeTarget
}).play();//淡出 }); on(fadeInButton,
"click",
function(evt){ fx.fadeIn({ node: fadeTarget
}).play();//淡入 }); });在所有的方法中包含后面介绍的,都只有一个对象参数,这个对象中可包含多个属性,必不可少的一个属性就是node,为要实现效果的节点对象或id字符串。
在fadeOut/fadeIn方法中还有一个属性duration,持续的时间,默认为350ms。这些animation方法将返回一animation对象,该对象包含一些方法:play,
pause, stop, status, and
gotoPercent,用来执行,暂停,停止,查看状态及执行到某种程度。
擦除require(["dojo/fx",
"dojo/on", "dojo/dom",
"dojo/domReady!"],
function(fx, on, dom) {
var wipeOutButton =
dom.byId("wipeOutButton"), wipeInButton =
dom.byId("wipeInButton"), wipeTarget =
dom.byId("wipeTarget"); on(wipeOutButton,
"click",
function(evt){ fx.wipeOut({ node: wipeTarget
}).play(); }); on(wipeInButton,
"click",
function(evt){ fx.wipeIn({ node: wipeTarget
}).play(); }); });
同淡入淡出一样
滑动
require(["dojo/fx",
"dojo/on", "dojo/dom",
"dojo/domReady!"],
function(fx, on, dom) {
var slideAwayButton =
dom.byId("slideAwayButton"), slideBackButton =
dom.byId("slideBackButton"), slideTarget =
dom.byId("slideTarget"); on(slideAwayButton,
"click",
function(evt){ fx.slideTo({ node: slideTarget, left:
"200", top: "200"}).play(); }); on(slideBackButton,
"click",
function(evt){ fx.slideTo({ node: slideTarget, left:
"0", top: "100"}).play(); }); });
在slideTo方法的参数中,除了节点对象属性外,还有left和top两个属性,用来设置滑动到目的位置的坐标。
事件
require(["dojo/fx",
"dojo/on", "dojo/dom-style",
"dojo/dom",
"dojo/domReady!"],
function(fx, on, style, dom) {
var slideAwayButton =
dom.byId("slideAwayButton"), slideBackButton =
dom.byId("slideBackButton"), slideTarget =
dom.byId("slideTarget"); on(slideAwayButton,
"click",
function(evt){ // Note that we're specifying the
beforeBegin as a property of the animation // rather than using connect. This
ensures that our beforeBegin handler // executes before any
others. var anim =
fx.slideTo({ node: slideTarget, left:
"200", top:
"200", beforeBegin:
function(){ console.warn("slide
target is: ", slideTarget); style.set(slideTarget,
{ left:
"0px", top:
"100px" }); } }); // We could have also specified onEnd
above alongside beforeBegin, // but it's just as easy to connect like
so on(anim,
"End", function(){ style.set(slideTarget,
{ backgroundColor:
"blue" }); },
true); // Don't forget to actually start the
animation! anim.play(); }); on(slideBackButton,
"click",
function(evt){ var anim =
fx.slideTo({ node: slideTarget, left:
"0", top:
"100", beforeBegin:
function(){ style.set(slideTarget,
{ left:
"200px", top:
"200px" }); } }); on(anim,
"End",
function(){ style.set(slideTarget,
{ backgroundColor:
"red" }); },
true); anim.play(); }); });在实现动态效果的过程中会产生两个事件,一个是beforeBegin,在执行之前调用;一个是onEnd,在执行完后调用。
在上面的例子中可以看到,beforeBegin是作为参数对象中的一个方法来定义的;onEnd是作为animation对象的一个事件在on中定义的。
连锁反应require(["dojo/_base/fx",
"dojo/fx", "dojo/on",
"dojo/dom",
"dojo/domReady!"],
function(baseFx, fx, on, dom) {
var slideAwayButton =
dom.byId("slideAwayButton"), slideBackButton =
dom.byId("slideBackButton"), slideTarget =
dom.byId("slideTarget"); // Set up a couple of click handlers to run our
chained animations on(slideAwayButton,
"click",
function(evt){ fx.chain([ baseFx.fadeIn({ node: slideTarget
}), fx.slideTo({ node: slideTarget, left:
"200", top: "200"}), baseFx.fadeOut({ node: slideTarget
}) ]).play(); }); on(slideBackButton,
"click",
function(evt){ fx.chain([ baseFx.fadeIn({ node: slideTarget
}), fx.slideTo({ node: slideTarget, left:
"0", top: "100"}), baseFx.fadeOut({ node: slideTarget
}) ]).play(); }); });
chain用来将多个animation动作连接起来按顺序执行,它的参数即是由不同animation方法返回的animation对象组成的数组,执行的顺序就是数组的先后顺序。
联合
require(["dojo/_base/fx",
"dojo/fx", "dojo/on",
"dojo/dom",
"dojo/domReady!"],
function(baseFx, fx, on, dom) {
var slideAwayButton =
dom.byId("slideAwayButton"), slideBackButton =
dom.byId("slideBackButton"), slideTarget =
dom.byId("slideTarget"); // Set up a couple of click handlers to run our
combined animations on(slideAwayButton,
"click",
function(evt){ fx.combine([ baseFx.fadeIn({ node: slideTarget
}), fx.slideTo({ node: slideTarget, left:
"200", top: "200"}) ]).play(); }); on(slideBackButton,
"click",
function(evt){ fx.combine([ fx.slideTo({ node: slideTarget, left:
"0", top: "100"}), baseFx.fadeOut({ node: slideTarget
}) ]).play(); }); });
combine方法是将多个animation动作联合起来同时执行实现一个完成的动态效果。其参数也是由不同animation方法返回的animation对象组成的数组。dojo 九 effects dojo/_base/fx 和 dojo/fx的更多相关文章
- 实践torch.fx第二篇-fx量化实操
好久不见各位,哈哈,又鸽了好久. 本文紧接上一篇<实践torch.fx第一篇--基于Pytorch的模型优化量化神器>继续说,主要讲如何利用FX进行模型量化. 为什么这篇文章拖了这么久,有 ...
- dojo对数组的处理函数,dojo.forEach、dojo.every、 dojo.some、 dojo.map等
转自:http://jiataodong.blog.163.com/blog/static/3490549220111024111943439/ 数组处理是 Ajax 应用开发中的常见操作.Dojo ...
- 为什么使用dojo?dojo与jquery有什么不同?dojo适合什么开发场景?
首先介绍一下dojo的特性: 1.Dojo是一个符合AMD规范的企业级框架(dojo是一个重量级框架) 2.Dojo全面支持异步加载JS机制(即:支持通过require异步加载JS模块,通过defin ...
- C#读写三菱Fx PLC 使用Fx 串口协议 读写Fx3U设备
本文将使用一个Github开源的组件库技术来读写三菱 FX PLC,使用的是基于串口的实现,不需要额外的组件,读取操作只要放到后台线程就不会卡死线程,本组件支持超级方便的高性能读写操作 github地 ...
- Dojo特效(翻译)
http://dojotoolkit.org/documentation/tutorials/1.10/effects/index.html In this tutorial, we will exp ...
- dojo框架笔记
一.模块定义 1.定义只含值对,没有任何依赖的模块(moudle1.js) define({ color: "black", size: "unisize" } ...
- Dojo动画原理解析
dojo中动画部分分为两部分:dojo/_base/fx, dojo/fx.dojo/_base/fx部分是dojo动画的基石,里面有两个底层API:animateProperty.anim和两个常用 ...
- Hello Dojo!(翻译)
http://dojotoolkit.org/documentation/tutorials/1.10/hello_dojo/index.html 欢迎学习DOJO!在本教程中,你将学些到如何加载DO ...
- Dojo API中文 Dojo内容模块概览,初学者
官网:http://dojotoolkit.org/reference-guide/1.10/dojo/index.html#dojo-dojo的翻译 dojo 内容: dojo dojo/dojo ...
随机推荐
- OpenFramework中视频或者图片进行中心旋转、平移、放大、缩小、矫正(本例以视频为准,只给出主要代码)
/********** update mesh部分***********/ for(int i=0;i<4;i++) { mesh[i].clear(); //重要,不加的话,移动视频的四个角 ...
- 【BZOJ】【3156】防御准备
DP/斜率优化 斜率优化的裸题…… sigh……又把$10^6$当成10W了……RE了N发 这题还是很水的 当然逆序也能做……不过还是整个反过来比较顺手 反转后的a[0]=反转前的a[n],以此类推直 ...
- NYOJ-32 组合数 AC 分类: NYOJ 2013-12-30 07:42 189人阅读 评论(0) 收藏
#include<stdio.h> int num[100]; int pnum(int n,int v); int mv=0; int main(){ int n,v; scanf(&q ...
- 原生js实现中文时钟
零.寒暄 终于一个月可以更新两篇博客了,开心.昨天花了大概一天的时间玩了下github,基本的clone和push都搞定了,如果有和我一样的新手没调通的,大家可以交流. 另外,说个题外话,大家发现我的 ...
- 用npm安装express后express命令找不到
Windows 平台加了 npm install -g express 也不行AppData\Roaming\npm 下面没有 express.bat 解决办法: sudo npm install - ...
- ubuntu 安装完成后的工作
以安装 ubuntu 15.10 为例 1. 备份并更改源 cd /etc/apt sudo cp source.list source.list.bak sudo vi source.list 删除 ...
- HTTP状态码一览表(HTTP Status Code)
copy from:http://www.189works.com/article-43064-1.html 1xx(临时响应)表示临时响应并需要请求者继续执行操作的状态代码. 代码 说明 100 ( ...
- GCD的简单封装
扩展: dispatch_block_t :无参数block,使用起来很简单 下载链接:http://pan.baidu.com/s/1bndN6Yb ]; } //定时器 - (voi ...
- ***codeigniter 2.2 affected_rows()返回值不准确
http://blog.icodeu.com/?p=596 问题描述今天在完成一个项目调用想要检验一下计划插入的数据是否都正常插入了.调用insert_batch()方法插入一百多条数据的时候发现af ...
- php获取网页header信息的4种方法
php获取网页header信息的方法多种多样,就php语言来说,我知道的方法有4种, 下面逐一献上. 方法一:使用get_headers()函数 推荐指数: ★★★★★ get_header方法最简单 ...