`

ExtJs之Ext.Fx类,让界面动起来

阅读更多

 

 

       界面具有动画效果最后归结为元素的动画效果。Extjs 定义了若干个方法用于完成元素动画的实现,一些是内置的,一些需要程序员自己编程。简单说,动态修改元素的样式是实现动态效果最直接最常见的方法,所以,这其中并无奥妙可言,看清楚了事实的真相,只要具备足够丰富的想象力,任何人都可以做出叹为观止的动画。

 

       虽然动画效果应用于Ext.Element 对象,却并不定义在Ext.Element 类中,而是定义在另一个类Ext.Fx 中。这让我非常疑惑,仔细查看了Ext.Element的源代码,愣是没发现Ext.Fx的身影,最终,在Ext.Fx 中看到了玄机,该类的最后一个语句告诉了我们事情的原委:Ext.apply(Ext.Element.prototype, Ext.Fx);,看看他的解释:Ext.Fx is automatically applied to Element so that all basic effects are available directly via the Element API(Ext.Fx 自动应用于Element 对象,所有的基本效果直接通过Element 调用)。

 

 

Ext.Fx 类

 

 

       正如前面所说,Extjs的动画大部分定义在Ext.Fx 中,尽管如此,Ext.Element 类也定义了部分动画函数。我们先来看看Ext.Fx 类中的重要方法。

 

1、slideIn ( [String anchor], [Object options] ):

功能:滑入效果

 

参数:

anchor:推出的方向,定义了8 种不同的方向,值不区别大小写,可选。

 

 

 

值     说明
-----  -----------------------------
tl     左上角
t      顶部中央
tr     右上角
l      左边中央
r      右边中央
bl     左下角
b      底部中央
br     右下角

 

options:选项配置,比较典型的是duration属性,用于定义动画持续的时间,可选。

以下是默认配置:

 

 

slideIn('t', {
easing: 'easeOut',
duration: .5
});

 示例:在10秒钟之内将div从右边中央滑入

 

html文件代码如下:

 

<div id="a1"> slideIn </div>

 js文件代码如下:

 

 

Ext.onReady(function(){
Ext.get("a1").applyStyles({position: "absolute", top: 200, left: 200, backgroundColor:
"red", width: 100, height: 100}).slideIn("r", {duration: 10});
})

 applyStyles 是Ext.Element 的方法,用于定义指定元素的样式。

 

 

 

 

2、slideOut ( [String anchor], [Object options] ):滑出效果,作动画隐藏。参数及用法同

上。以下是该方法的默认配置:

 

 

el.slideOut('t', {
    easing: 'easeOut',
    duration: .5,
    remove: false,
    useDisplay: false
});

 

 

 

3、highlight ( [String color], [Object options] ):根据设置的颜色高亮显示Element 对象,

然后渐隐为原始颜色。默认情况,高亮显示的背景颜色为黄色。

参数:

color:起始颜色

options:选项配置

常见的配置选项及默认值

 

el.highlight("ffff9c", {
    attr: "background-color", //可以是任何能够把值设置成颜色代码的 CSS 属性
    endColor: (current color) or "ffffff",
    easing: 'easeIn',
    duration: 1
});

 

一个能应用在项目中的典型例子是:

 

 

Ext.get("a2").applyStyles({
position: "absolute",
top: 200,
left: 300,
backgroundColor: "red",
width: 100,
height: 100}).highlight("0000ff"/*起始颜色*/,
{
attr: 'background-color', /*我们改变的是背景颜色*/
duration: 2,/*动画持续时间*/
endColor: "ff0000" /*结束颜色*/
}
);

       如果可以把attr 属性值改成color,我们发现颜色改变的不再是背景,而是文字颜色。endColor 的颜色值不能是形如red之类的英文单词,只能是16 进制表示。起始颜色为蓝色,终止颜色为红色,中间的渐变由Extjs自动完成,非常自然。

 

 

 

4、frame ( [String color], [Number count], [Object options] ):展示一个展开的波纹,伴随

着渐隐的边框以突出显示Element 对象。默认情况下展示的是一个淡蓝色的波纹。

参数:

color:波纹颜色

count:波纹的个数

options:选项配置

示例:三个红色的波纹并持续3 秒。

 

 

Ext.onReady(function() {
			Ext.get("a4").applyStyles({
						position : "absolute",
						top : 200,
						left : 400,
						backgroundColor : "red",
						width : 100,
						height : 100
					}).frame("ff0000", 3, { // 内个波纹
						duration : 3 //每个波纹持续的时间
					});

		});

 

 

 

5、fadeIn ( [Object options] ):将元素从透明渐变为不透明。结束时的透明度可以根据"endOpacity"选项来指定。

 

示例:

 

Ext.onReady(function() {
			Ext.get("a4").applyStyles({
						position : "absolute",
						top : 200,
						left : 500,
						backgroundColor : "red",
						width : 100,
						height : 100
					}).fadeIn({
						endOpacity : .75, // 可以是0 到1 之前的任意值(例如:.5)
						duration : 4 //在4秒钟之内将可见度由 0 渐变到 75%
					});
		});

 

 

 

6、fadeOut ( [Object options] ):将元素从不透明渐变为透明。结束时的透明度可以根据"endOpacity"选项来指定。

示例:

 

 

Ext.onReady(function() {
			Ext.get("a4").applyStyles({
						position : "absolute",
						top : 200,
						left : 600,
						backgroundColor : "red",
						width : 100,
						height : 100
					}).fadeOut({
						endOpacity : 0, // 可以是0 到1 之前的任意值(例如:.5)
						duration : 4,
						remove : false,
						useDisplay : false
					});
		});

 

 

 

7、scale ( Number width, Number height, [Object options] ):以动画展示元素从开始的高度/宽度转换到结束的高度/宽度。

参数:

width:结束宽度,如果为undefined则保持原始宽度

height:结束高度,如果为undefined为保持原始高度

示例:

 

 

Ext.onReady(function() {
			Ext.get("a4").applyStyles({
						position : "absolute",
						top : 200,
						left : 700,
						backgroundColor : "red",
						width : 10,
						height : 10
					}).scale(100, 100, {
						duration : 2
					});
		});

 

 

 

8、shift ( Object options ):以动画展示元素任意组合属性的改变,如元素的尺寸、位置坐标和(或)透明度。如果以上属性中的任意一个没有在配置选项对象中指定则该属性不会发生改变。为了使该特效生效,则必须在配置选项对象中设置至少一个新的尺寸、位置坐标或透明度属性。

下面是一个比较有实用性的示例:

 

 

Ext.onReady(function() {
			Ext.get("a4").applyStyles({
						position : "absolute",
						top : 200,
						left : 800,
						backgroundColor : "red",
						width : 10,
						height : 10
					}).shift({
				width : 100,// 动画终止之后的宽度
				height : 100,// 动画终止之后的高度
				x : 0,// 动画终止之后的x坐标
				y : 0,// 动画终止之后的y坐标
				opacity : .5, // 动画终止之后的透明度,0-1之间的任意值
				duration : 5 // 动画持续的时间(5秒)
				});
		});

 

 

9.ghost ( [String anchor], [Object options] ):将元素从视图滑出并伴随着渐隐。作为可

选参数传入的定位锚点将被设置为滑出特效的结束点。

参数:

anchor:同slideIn

示例:

Ext.onReady(function() {
			Ext.get("a4").applyStyles({
						position : "absolute",
						top : 200,
						left : 900,
						backgroundColor : "red",
						width : 100,
						height : 100
					}).ghost('b', {
						easing : 'easeOut',
						duration : .5,
						remove : false,
						useDisplay : false
					});
		});

 

Ext.Element 类中的动画函数

 

1、setWidth ( Number width, Boolean/Object animate):设置元素宽度

参数:

width:新宽度;

animate:是否以动画方式设置新的宽度,为true 时有动画效果。也可以配置动画参数。

示例:

Ext.onReady(function() {
			Ext.onReady(function() {
						Ext.get("e1").applyStyles({
									position : "absolute",
									left : 300,
									top : 100,
									width : 200,
									height : 200,
									backgroundColor : "red"
								}).setWidth(500, true);
					})
		});

元素e1是一个div元素(<div id="e1">setWidth</div>),初始宽度为200px,通过setWidth()方法宽度设置为500px,并且以动画方式将div拉宽。 

 

2、setHeight ( Number height, Boolean/Object animate):设置高度,意义和使用同上。

 

3、setSize ( Number width, Number height, Boolean/Object animate):同时设置元素的宽度和高度,并设置是否以动画显示。

参数:

width:新的宽度

height:新的高度

animate:是否带有动画效果,或者配置动画参数

示例:

Ext.onReady(function() {
			Ext.onReady(function() {
						Ext.get("a4").applyStyles({
									position : "absolute",
									left : 300,
									top : 100,
									width : 200,
									height : 200,
									backgroundColor : "red"
								}).setSize(500, 500, true);
					})
		});

div的初始大小为100*100,通过setSize()将大小变成500*500,并以动画显示。 

 

4、setBounds ( Number x, Number y, Number width, Number height, Boolean/Object animate):设置元素的位置和大小。

参数:

x:新的左上角x 坐标

y:新的左上角y坐标

width:新的宽度

height:新的高度

animate:是否以动画显示,或者配置动画参数

示例:

Ext.onReady(function() {
			Ext.get("a4").applyStyles({
						position : "absolute",
						left : 100,
						top : 100,
						width : 100,
						height : 100,
						backgroundColor : "blue"
					}).setBounds(0, 0, 500, 500, true);
		});

 将 div元素的位置从100*100 变到0*0,并将大小从100*100变化到500*500。

 

5、show ( Boolean/Object animate):显示元素。

 

6、hide ( Boolean/Object animate):隐藏元素。

 

 

 

 

 

 

0
0
分享到:
评论

相关推荐

    轻松搞定ExtJS

    - **让界面动起来**:介绍了一些基本的动画效果及其在Extjs中的实现方式。 - **Ext.Fx类**:详细讲解了Ext.Fx类中可用的动画效果。 - **Ext.Element类中的动画函数**:列举了Ext.Element类中可以用于元素动画的方法...

    extjs实现的带标签、翻页动画的书

    在ExtJS中实现翻书效果,可能涉及到`Ext.fx.Anim`类,这是ExtJS的动画引擎,用于创建各种过渡和动画效果。开发者可能通过设置动画参数,如持续时间、缓动函数、关键帧等,来实现书页翻转时的平滑动态效果。此外,`...

    轻松搞定Extjs_原创

    - **让界面动起来**:使用动画增强用户界面的交互性。 - **Ext.Fx类**:详解如何使用Ext.Fx类创建动画效果。 - **Ext.Element类中的动画函数**:介绍该类提供的动画相关方法。 #### 第六章:元素操作与模板 - **...

    Extjs中文教程

    - **让界面动起来** - Extjs提供了丰富的动画效果,可以通过`Ext.Fx`和`Ext.Element`类实现。 - 动画效果包括淡入淡出、滑动、缩放等。 - **Ext.Fx类** - 提供了一组高级的动画效果,支持复杂的动画序列。 - ...

    Extjs中文教程(初学者适合)

    - **让界面动起来**: 使用Extjs提供的动画效果增强用户体验。 - **Ext.Fx类**: 提供了一系列动画效果的方法。 - **Ext.Element类中的动画函数**: 可以对DOM元素应用动画效果。 #### 六、元素操作与模板 - **Ext....

    轻松搞定Extjs

    - **让界面动起来**: 讲解了如何使用Extjs内置的动画效果来增强用户体验。 - **Ext.Fx类**: 详细介绍了一组用于实现各种动画效果的API。 - **Ext.Element类中的动画函数**: 展示了如何通过Element对象调用动画方法。...

    ExtJS 轻松搞定

    #### 四、让界面动起来 探讨了如何使用ExtJS中的动画效果,如淡入淡出、滑动等,来提升用户界面的动态表现力。 #### 五、Ext.Fx类 详细介绍了ExtJS提供的Fx类,这是一个强大的动画引擎,支持多种动画效果。 #### ...

    Ext中文文档

    - **让界面动起来**:介绍了如何使用ExtJS的动画效果,使界面更加生动有趣。 - **Ext.Fx类与Ext.Element类中的动画函数**:深入探讨了ExtJS的动画库,包括Fx类和Element类中的动画函数,以及如何应用它们。 #### 第...

    Ext 开发指南 学习资料

    10.4. 健康快乐动起来,fx里的动画效果 10.5. 悄悄的更新网页内容 A. 常见问题乱弹 A.1. ext到底是收费还是免费 A.2. 怎么查看ext2里的api文档 A.3. 如何在页面中引用ext A.3.1. 顺便说说常见的Ext is not defined...

    EXTJS一个小抽奖例子

    例如,可以利用 Ext.fx.Anim 对象创建一个旋转动画,让抽奖转盘转动几圈后停下来,增加视觉效果的真实感。 此外,EXTJS 还有强大的数据管理能力,可以配合 JSONP 或 AJAX 与服务器进行数据交互。在这个抽奖例子中,...

Global site tag (gtag.js) - Google Analytics