JavaScript的动态效果最基本的是 动态改变大小,移动位置,改变透明度,改变颜色等等。

而其他一些比较炫的效果无非是对这些最基本效果的组合和运用。


现在网上已经有很多很不错的优秀Javascript库或者效果库,我们是否有必要再造轮子呢?

放眼望去,Yahoo UI, 基于Prototype的scriptaculous, Rico, JQuery, Dojo,还有很多很多。

这些库都带有很不错很优秀的动态效果。我们可以直接使用。

但是对于一些中小型项目来说,只是偶尔用到一两个特效,就没有必要引用整个框架,要知道

这些家伙体积都不小哦. prototype.js 50K, scripttaculous的 effects.js也有40-50k  dojo,yui 更大。


在大多数情况下我们需要一个小巧独立(300行代码以内),无侵入性的效果库。.即使有现有的轮子,

我们不但要学会怎么使用轮子,更要学会如何亲手造一个轮子。

基于以上原因,我们今天来重写一个灵活的,扩展性强的,小巧的,跨浏览器的动态效果库。


考虑到prototype.js 用户群的广泛性,我的部分代码引用了prototype.js,当然,我说过 ,我们要做一个独立

的效果库,即使在没有prototype.js的情况下,也要让代码正常工作。


先做一些准备工作。下面这些代码是任何效果库中必不可少的,因为它负责一些类似取位置坐标,

设置,获取element的透明度等这些基础工作。


代码:


/*

    这个函数的代码来自 Prototype.js  http://prototype.conio.net/

    如果页面引用了prototype.js ,则可以删除下面这个函数,

    当然,即使不删除也没关系,因为作了简单的兼容性判断

*/

(

function (){   


if      ( ! ( " Prototype "   in  window)){

        Prototype

= {emptyFunction: function (){}};

        Class 

= {

            create: 

function (){ return   function (){ this .initialize.apply( this , arguments)}}

        };        

        $ 

=   function (element){


return   typeof (element) == " string " ? document.getElementById(element):element

        };

        $A

=   function (arrLike){


for ( var  i = 0 ,ret = [];i < arrLike.length;i ++ ) ret[i] = arrLike[i];


return  ret

        };    


        Number.prototype.toColorPart 

= function (){ return  String( " 00 " + this .toString( 16 )).slice( - 2 )};        

        Function.prototype.bind 

=   function () {


var  __method  =   this , args  =  $A(arguments), object  =  args.shift();


return   function (){ return  __method.apply(object, args.concat($A(arguments)))}

        }


        Position

= { 

             cumulativeOffset: 

function (element) {


var  valueT  =   0 , valueL  =   0 ;


do  {

                  valueT 

+=  element.offsetTop   ||   0 ;

                  valueL 

+=  element.offsetLeft  ||   0 ;

                  element 

=  element.offsetParent;

                } 

while  (element);


return  [valueL, valueT];

            }

        }        

    }

})()



/*

    1.读取/设置 透明度,

    2.如果只传了一个参数element,则返回 element的透明度 (0<value<1)

    3.如果传了两个参数 element和value 则把element的透明度设置为value  value范围 0-1

*/

function  Opacity(element,value){

//  by Go_Rush(阿舜) 

     var  ret;


if  (value === undefined){    // 读取

         if  ( !/ msie / i.test(navigator.userAgent))


if  (ret = element.style.opacity)  return  parseFloat(ret);          


try { return  element.filters.item('alpha').opacity / 100 } catch (x){ return   1.0 }

    }

else {                    // 设置        

        value = Math.min(Math.max(value, 0.00001 ), 0.999999 )     // 这句修复一些非ie浏览器opacity不能设置为1的bug

         if  ( / msie / i.test(navigator.userAgent))  return  element.style.filter = " alpha(opacity= " + value * 100 + " ) "


return  element.style.opacity = value        

    }

}


那么怎么设计这个Effect效果库呢。


首先,它的入口应该简洁。


    1.一个是要使用效果的元素 element


    2.另一个是将要使用什么效果 options 


       options应该是扩展性强的,方便用户使用的。我们把它设计成哈稀结构。


比如 options={x:100,y:100} 表示 将element移动到坐标 100,100


options={w:200,h:200} 表示将element的大小改变为 width=200,height=200


他们可以重叠,也可以确省 比如 options={h:20,y:20} 这表示将element移动到 top=20的位置,而且在移动的过程中让他的大小改变为 height=20 ,同时,原来的left坐标和宽度都不发生改变,这是不是在做QQ的滑动效果呢?


还有控制效果的几个关键因素 duration(整个效果的时间),delay(延迟几秒才开始效果),fps(频率快慢) 都通过options传进来



  javascript 通用效果库_objectEffect         

= Class.create();

  javascript 通用效果库_objectEffect.Fn    

= new  Object();

  javascript 通用效果库_objectEffect.Init  

= new  Object();

  javascript 通用效果库_object              //  By Go_Rush(阿舜) from http://ashun.cnblogs.com/

  javascript 通用效果库_function_05javascript 通用效果库_button_06Effect.prototype

= javascript 通用效果库_prototype_07

{

 javascript 通用效果库_object_08javascript 通用效果库_function_09    initialize: function(element,options) javascript 通用效果库_prototype_07{

 javascript 通用效果库_prototype_11        this.element  = $(element);

 javascript 通用效果库_prototype_11        this.options  = options || {};

 javascript 通用效果库_prototype_11        this.duration   = (this.options.duration || 2) * 1000;   //效果执行时间

 javascript 通用效果库_prototype_11        this.fps            = this.options.fps || 40;                 //频率

 javascript 通用效果库_prototype_11        //当前步长,注: 这个变量是递减的,当它0的时候意味着整个效果结束

 javascript 通用效果库_prototype_11        this.steps        = Math.floor(this.duration/this.fps);   

 javascript 通用效果库_prototype_11        this.maxSteps = this.steps;             //整个效果的步长

 javascript 通用效果库_prototype_11        this.setting     = new Object();  

 javascript 通用效果库_prototype_11        this.timer         = null;        

 javascript 通用效果库_prototype_11

 javascript 通用效果库_object_08javascript 通用效果库_function_09     if (this.options.delay)javascript 通用效果库_prototype_07{    // 延时处理

 javascript 通用效果库_prototype_11               var _this=this;

 javascript 通用效果库_object_08javascript 通用效果库_function_09             setTimeout(function()javascript 通用效果库_prototype_07{

 javascript 通用效果库_prototype_11                       _this.setup(_this);

 javascript 通用效果库_prototype_11                       (_this.options.onStart || Prototype.emptyFunction)(_this);

 javascript 通用效果库_prototype_11                       _this.run();

 javascript 通用效果库_button_31                }, _this.options.delay*1000);

 javascript 通用效果库_object_08javascript 通用效果库_function_09        }elsejavascript 通用效果库_prototype_07{

 javascript 通用效果库_prototype_11                 this.setup(this);

 javascript 通用效果库_prototype_11                (this.options.onStart || Prototype.emptyFunction)(this);        

 javascript 通用效果库_prototype_11                this.run();      

 javascript 通用效果库_button_31        }

 javascript 通用效果库_button_31   },

 javascript 通用效果库_object_08javascript 通用效果库_function_09   run: function() javascript 通用效果库_prototype_07{

 javascript 通用效果库_prototype_11        if (this.isFinished())  return (this.options.onComplete || Prototype.emptyFunction)(this);

 javascript 通用效果库_prototype_11        if (this.timer)   clearTimeout(this.timer);

 javascript 通用效果库_prototype_11        this.duration -= this.fps;

 javascript 通用效果库_prototype_11        this.steps--;                           

 javascript 通用效果库_prototype_11        var pos=1-this.steps/this.maxSteps    ;    //总进度的百分比

 javascript 通用效果库_prototype_11        this.loop(this,pos);    

 javascript 通用效果库_prototype_11        (this.options.onUpdate || Prototype.emptyFunction)(this,pos);      

 javascript 通用效果库_prototype_11        this.timer = setTimeout(this.run.bind(this), this.fps);

 javascript 通用效果库_button_31   },

 javascript 通用效果库_object_08javascript 通用效果库_function_09   isFinished: function() javascript 通用效果库_prototype_07

 javascript 通用效果库_prototype_11           return this.steps <= 0;

 javascript 通用效果库_button_31   },

 javascript 通用效果库_object_08javascript 通用效果库_function_09   setup:function(effect)javascript 通用效果库_prototype_07{       //初始化设置所有效果单元

 javascript 通用效果库_object_08javascript 通用效果库_function_09           for(var key in Effect.Init)javascript 通用效果库_prototype_07{

 javascript 通用效果库_prototype_11            if (typeof(Effect.Init[key])!="function") continue;

 javascript 通用效果库_object_08javascript 通用效果库_function_09            tryjavascript 通用效果库_prototype_07{Effect.Init[key](this)}catch(x)javascript 通用效果库_prototype_07{}

 javascript 通用效果库_button_31        }

 javascript 通用效果库_button_31    },

 javascript 通用效果库_object_08javascript 通用效果库_function_09   loop:function(effect,pos)javascript 通用效果库_prototype_07{           //执行所有效果单元

 javascript 通用效果库_object_08javascript 通用效果库_function_09        for(var key in Effect.Fn)javascript 通用效果库_prototype_07{

 javascript 通用效果库_prototype_11            if (typeof(Effect.Fn[key])!="function") continue;

 javascript 通用效果库_object_08javascript 通用效果库_function_09            tryjavascript 通用效果库_prototype_07{Effect.Fn[key](effect,pos)}catch(x)javascript 通用效果库_prototype_07{}

 javascript 通用效果库_button_31        }

 javascript 通用效果库_button_31   }

 javascript 通用效果库_prototype_83}

当动态效果改变的时候,比如淡出,我们让一个element慢慢的变淡变小,并消失。

在不用效果库的情况下 只用 element.style.display="none" 就做到了。

用效果库后,element.style  的 透明度 opacity, 尺寸 width,height 甚至位置 left,top都发生了改变。

直到 element的大小改变为 0或者opactiy为0的时候他才会消失 display="none"

那么,当下次再让他出现的时候,怎么恢复他的原始信息呢。比如 width.height,opacity等。


在上面的代码中 我们用 effect.setting 保存效果发生前的所有element信息.


注意以上三个自定义函数 onStart,onUpdate,onComplete 他们都是通过 options传进来的调用者自定义函数。

分别在效果发生以前,效果发生时,效果发生完毕后执行。传入的参数可以查阅effect的所有对象。


看到这里,细心的看官可能注意到,这个效果库实际上什么效果都没有做,他只是搭了一个空架子。

Effect.Init 给我们留了一个空接口供 setup方法调用,Effect.Fn也是一个空接口供loop方法调用。

下面我们要做的是扩展 Effect.Init和 Effect.Fn 来充实效果库。


先来一个大家最熟悉的 淡入淡出

Effect.Init 里面的所有成员函数都会被 effect.setup 执行, 这个执行动作在效果开始之前,因此这里

适合做一些初始化的动作。 比如把一些初始信息保存到 effect.setting里面供以后使用。


Effect.Fn 里面的所有成员函数都会被 effect.loop 执行, 这个执行动作在效果运行中,因此这里

就要放核心效果代码,比如计算,改变效果增量等等。


 if (effect.options.opacity===undefined) return;

 effect.setting.opacity=Opacity(effect.element); 

}

Effect.Fn.opacity=function(effect,pos){

 if (effect.options.opacity===undefined) return;

 Opacity(effect.element,effect.setting.opacity+(effect.options.opacity-effect.setting.opacity)*pos); 

}



下面贴出可调试代码​(空效果库和淡入浅出插件):(可以拷贝到一个html运行,测试)


javascript 通用效果库_button_06javascript 通用效果库_function_05可运行代码


javascript 通用效果库_object<script language="javascript">

javascript 通用效果库_function_05javascript 通用效果库_button_06/**//*

javascript 通用效果库_prototype_11    这个函数的代码来自 Prototype.js  http://prototype.conio.net/

javascript 通用效果库_prototype_11    如果页面引用了prototype.js ,则可以删除下面这个函数,

javascript 通用效果库_prototype_11    当然,即使不删除也没关系,因为作了简单的兼容性判断

javascript 通用效果库_prototype_83*/

javascript 通用效果库_function_05javascript 通用效果库_button_06(function()javascript 通用效果库_prototype_07{   

javascript 通用效果库_object_08javascript 通用效果库_function_09    if     (!("Prototype" in window))javascript 通用效果库_prototype_07{

javascript 通用效果库_object_08javascript 通用效果库_function_09        Prototype=javascript 通用效果库_prototype_07{emptyFunction:function()javascript 通用效果库_prototype_07{}};

javascript 通用效果库_object_08javascript 通用效果库_function_09        Class =javascript 通用效果库_prototype_07{

javascript 通用效果库_object_08javascript 通用效果库_function_09            create: function()javascript 通用效果库_prototype_07{return function()javascript 通用效果库_prototype_07{this.initialize.apply(this, arguments)}}

javascript 通用效果库_button_31        };        

javascript 通用效果库_object_08javascript 通用效果库_function_09        $ = function(element)javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11            return typeof(element)=="string"?document.getElementById(element):element

javascript 通用效果库_button_31        };

javascript 通用效果库_object_08javascript 通用效果库_function_09        $A= function(arrLike)javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11            for(var i=0,ret=[];i<arrLike.length;i++) ret[i]=arrLike[i];

javascript 通用效果库_prototype_11            return ret

javascript 通用效果库_button_31        };    

javascript 通用效果库_prototype_11        

javascript 通用效果库_object_08javascript 通用效果库_function_09        Number.prototype.toColorPart =function()javascript 通用效果库_prototype_07{return String("00"+this.toString(16)).slice(-2)};        

javascript 通用效果库_object_08javascript 通用效果库_function_09        Function.prototype.bind = function() javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11             var __method = this, args = $A(arguments), object = args.shift();

javascript 通用效果库_object_08javascript 通用效果库_function_09            return function()javascript 通用效果库_prototype_07{return __method.apply(object, args.concat($A(arguments)))}

javascript 通用效果库_button_31        }

javascript 通用效果库_prototype_11

javascript 通用效果库_object_08javascript 通用效果库_function_09        Position=javascript 通用效果库_prototype_07

javascript 通用效果库_object_08javascript 通用效果库_function_09             cumulativeOffset: function(element) javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11                var valueT = 0, valueL = 0;

javascript 通用效果库_object_08javascript 通用效果库_function_09                do javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11                  valueT += element.offsetTop  || 0;

javascript 通用效果库_prototype_11                  valueL += element.offsetLeft || 0;

javascript 通用效果库_prototype_11                  element = element.offsetParent;

javascript 通用效果库_button_31                } while (element);

javascript 通用效果库_prototype_11                return [valueL, valueT];

javascript 通用效果库_button_31            }

javascript 通用效果库_button_31        }        

javascript 通用效果库_button_31    }

javascript 通用效果库_prototype_83})()

javascript 通用效果库_object

javascript 通用效果库_function_05javascript 通用效果库_button_06/**//*

javascript 通用效果库_prototype_11    1.读取/设置 透明度,

javascript 通用效果库_prototype_11    2.如果只传了一个参数element,则返回 element的透明度 (0<value<1)

javascript 通用效果库_prototype_11    3.如果传了两个参数 element和value 则把element的透明度设置为value  value范围 0-1

javascript 通用效果库_prototype_83*/

javascript 通用效果库_function_05javascript 通用效果库_button_06function Opacity(element,value)javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11    var ret;

javascript 通用效果库_object_08javascript 通用效果库_function_09    if (value===undefined)javascript 通用效果库_prototype_07{   //读取

javascript 通用效果库_prototype_11        if (!/msie/i.test(navigator.userAgent))

javascript 通用效果库_prototype_11            if (ret=element.style.opacity) return parseFloat(ret);          

javascript 通用效果库_object_08javascript 通用效果库_function_09        tryjavascript 通用效果库_prototype_07{return element.filters.item('alpha').opacity/100}catch(x)javascript 通用效果库_prototype_07{return 1.0}

javascript 通用效果库_object_08javascript 通用效果库_function_09    }elsejavascript 通用效果库_prototype_07{                   //设置        

javascript 通用效果库_prototype_11        value=Math.min(Math.max(value,0.00001),0.999999)    //这句修复一些非ie浏览器opacity不能设置为1的bug

javascript 通用效果库_prototype_11        if (/msie/i.test(navigator.userAgent)) return element.style.filter="alpha(opacity="+value*100+")"

javascript 通用效果库_prototype_11        return element.style.opacity=value        

javascript 通用效果库_button_31    }

javascript 通用效果库_prototype_83}

javascript 通用效果库_object

javascript 通用效果库_object

javascript 通用效果库_objectEffect        =Class.create();

javascript 通用效果库_objectEffect.Fn    =new Object();

javascript 通用效果库_objectEffect.Init =new Object();

javascript 通用效果库_object

javascript 通用效果库_function_05javascript 通用效果库_button_06Effect.prototype=javascript 通用效果库_prototype_07{

javascript 通用效果库_object_08javascript 通用效果库_function_09    initialize: function(element,options) javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11        this.element  = $(element);

javascript 通用效果库_object_08javascript 通用效果库_function_09            this.options  = options || javascript 通用效果库_prototype_07{};

javascript 通用效果库_prototype_11         this.duration = (this.options.duration || 2) * 1000;   //效果执行时间

javascript 通用效果库_prototype_11        this.fps      = this.options.fps || 40;                 //频率

javascript 通用效果库_prototype_11           this.steps    = Math.floor(this.duration/this.fps);   //当前步长,注: 这个变量是递减的,当它0的时候意味着整个效果结束

javascript 通用效果库_prototype_11        this.maxSteps = this.steps;             //整个效果的步长

javascript 通用效果库_prototype_11        this.setting  = new Object();  

javascript 通用效果库_prototype_11        this.timer    = null;        

javascript 通用效果库_prototype_11

javascript 通用效果库_object_08javascript 通用效果库_function_09           if (this.options.delay)javascript 通用效果库_prototype_07{    // 延时处理

javascript 通用效果库_prototype_11             var _this=this;

javascript 通用效果库_object_08javascript 通用效果库_function_09             setTimeout(function()javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11                 _this.setup(_this);

javascript 通用效果库_prototype_11                (_this.options.onStart || Prototype.emptyFunction)(_this);

javascript 通用效果库_prototype_11                 _this.run();

javascript 通用效果库_button_31                }, _this.options.delay*1000);

javascript 通用效果库_object_08javascript 通用效果库_function_09        }elsejavascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11            this.setup(this);

javascript 通用效果库_prototype_11            (this.options.onStart || Prototype.emptyFunction)(this);        

javascript 通用效果库_prototype_11            this.run();      

javascript 通用效果库_button_31        }

javascript 通用效果库_button_31   },

javascript 通用效果库_object_08javascript 通用效果库_function_09   run: function() javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11        if (this.isFinished())  return (this.options.onComplete || Prototype.emptyFunction)(this);

javascript 通用效果库_prototype_11        if (this.timer)   clearTimeout(this.timer);

javascript 通用效果库_prototype_11        this.duration -= this.fps;

javascript 通用效果库_prototype_11        this.steps--;                           

javascript 通用效果库_prototype_11        var pos=1-this.steps/this.maxSteps    ;    //总进度的百分比

javascript 通用效果库_prototype_11        this.loop(this,pos);    

javascript 通用效果库_prototype_11        (this.options.onUpdate || Prototype.emptyFunction)(this,pos);      

javascript 通用效果库_prototype_11        this.timer = setTimeout(this.run.bind(this), this.fps);

javascript 通用效果库_button_31   },

javascript 通用效果库_object_08javascript 通用效果库_function_09   isFinished: function() javascript 通用效果库_prototype_07

javascript 通用效果库_prototype_11           return this.steps <= 0;

javascript 通用效果库_button_31   },

javascript 通用效果库_object_08javascript 通用效果库_function_09   setup:function(effect)javascript 通用效果库_prototype_07{       //初始化设置所有效果单元

javascript 通用效果库_object_08javascript 通用效果库_function_09           for(var key in Effect.Init)javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11            if (typeof(Effect.Init[key])!="function") continue;

javascript 通用效果库_object_08javascript 通用效果库_function_09            tryjavascript 通用效果库_prototype_07{Effect.Init[key](this)}catch(x)javascript 通用效果库_prototype_07{}

javascript 通用效果库_button_31        }

javascript 通用效果库_button_31    },

javascript 通用效果库_object_08javascript 通用效果库_function_09   loop:function(effect,pos)javascript 通用效果库_prototype_07{           //执行所有效果单元

javascript 通用效果库_object_08javascript 通用效果库_function_09        for(var key in Effect.Fn)javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11            if (typeof(Effect.Fn[key])!="function") continue;

javascript 通用效果库_object_08javascript 通用效果库_function_09            tryjavascript 通用效果库_prototype_07{Effect.Fn[key](effect,pos)}catch(x)javascript 通用效果库_prototype_07{}

javascript 通用效果库_button_31        }

javascript 通用效果库_button_31   }

javascript 通用效果库_prototype_83}

javascript 通用效果库_object

javascript 通用效果库_function_05javascript 通用效果库_button_06Effect.Init.opacity=function(effect)javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11    if (effect.options.opacity===undefined) return;

javascript 通用效果库_prototype_11    effect.setting.opacity=Opacity(effect.element);    

javascript 通用效果库_prototype_83}

javascript 通用效果库_object

javascript 通用效果库_function_05javascript 通用效果库_button_06Effect.Fn.opacity=function(effect,pos)javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11    if (effect.options.opacity===undefined) return;

javascript 通用效果库_prototype_11    Opacity(effect.element,effect.setting.opacity+(effect.options.opacity-effect.setting.opacity)*pos);    

javascript 通用效果库_prototype_83}

javascript 通用效果库_object

javascript 通用效果库_object

javascript 通用效果库_object

javascript 通用效果库_object    

javascript 通用效果库_function_05javascript 通用效果库_button_06var foo1=function()javascript 通用效果库_prototype_07{     //最简单的调用方式

javascript 通用效果库_object_08javascript 通用效果库_function_09    new Effect("div1",javascript 通用效果库_prototype_07{opacity:0.2})

javascript 通用效果库_prototype_83}

javascript 通用效果库_function_05javascript 通用效果库_button_06var foo2=function()javascript 通用效果库_prototype_07{

javascript 通用效果库_object_08javascript 通用效果库_function_09    new Effect("div1",javascript 通用效果库_prototype_07{opacity:0.2,delay:3})  //延迟3秒

javascript 通用效果库_prototype_83}

javascript 通用效果库_function_05javascript 通用效果库_button_06var foo3=function()javascript 通用效果库_prototype_07{

javascript 通用效果库_object_08javascript 通用效果库_function_09        new Effect("div1",javascript 通用效果库_prototype_07{opacity:0.2,duration:5})  //效果执行5秒,默认是2秒的

javascript 通用效果库_prototype_83}

javascript 通用效果库_function_05javascript 通用效果库_button_06var foo4=function()javascript 通用效果库_prototype_07{   //自定义函数

javascript 通用效果库_object_08javascript 通用效果库_function_09        new Effect("div1",javascript 通用效果库_prototype_07{

javascript 通用效果库_prototype_11            opacity:0.2,

javascript 通用效果库_object_08javascript 通用效果库_function_09            onStart:function(eff)javascript 通用效果库_prototype_07{alert("效果运行时注意document.title,运行后注意div内的文字")},

javascript 通用效果库_object_08javascript 通用效果库_function_09            onUpdate:function(eff,p)javascript 通用效果库_prototype_07{document.title=p.toFixed(2)},

javascript 通用效果库_object_08javascript 通用效果库_function_09            onComplete:function(eff)javascript 通用效果库_prototype_07{eff.element.innerHTML="运行完毕"}

javascript 通用效果库_button_31        }) 

javascript 通用效果库_prototype_83}

javascript 通用效果库_function_05javascript 通用效果库_button_06var foo5=function()javascript 通用效果库_prototype_07{    //先变淡后变深

javascript 通用效果库_object_08javascript 通用效果库_function_09        new Effect("div1",javascript 通用效果库_prototype_07{opacity:0.2,onComplete:function(eff)javascript 通用效果库_prototype_07{

javascript 通用效果库_object_08javascript 通用效果库_function_09            new Effect(eff.element,javascript 通用效果库_prototype_07{opacity:1,delay:1})

javascript 通用效果库_button_31        }})  

javascript 通用效果库_prototype_83}

javascript 通用效果库_object    

javascript 通用效果库_object

javascript 通用效果库_object

javascript 通用效果库_function_05javascript 通用效果库_button_06function foo()javascript 通用效果库_prototype_07{    

javascript 通用效果库_object_08javascript 通用效果库_function_09    new Effect("div1",javascript 通用效果库_prototype_07{opacity:1,duration:1})

javascript 通用效果库_prototype_83}

javascript 通用效果库_object

javascript 通用效果库_object

javascript 通用效果库_object</script>

javascript 通用效果库_object<button onclick="javascript:foo1()">执行foo1</button>&nbsp;&nbsp;&nbsp;

javascript 通用效果库_object<button onclick="javascript:foo2()">执行foo2(延迟)</button>&nbsp;&nbsp;&nbsp;

javascript 通用效果库_object<button onclick="javascript:foo3()">执行foo3(5秒)</button>&nbsp;&nbsp;&nbsp;

javascript 通用效果库_object<button onclick="javascript:foo4()">执行foo4(自定义函数)</button>&nbsp;&nbsp;&nbsp;

javascript 通用效果库_object<button onclick="javascript:foo5()">执行foo5(先变淡后变深)</button>&nbsp;&nbsp;&nbsp;

javascript 通用效果库_object<br /><br />每次调用效果后点下面的恢复按钮<br /><br />

javascript 通用效果库_object<button onclick="javascript:foo()">恢  复</button>&nbsp;

javascript 通用效果库_object

javascript 通用效果库_object<div id="div1" style="border:solid;width:300px;height:150px;overflow:hidden;position:absolute;left:300px;top:200px;"> 

javascript 通用效果库_object    <font color="blue">

javascript 通用效果库_object    Go_Rush(阿舜) @  http://ashun.cnblogs.com/  <br />

javascript 通用效果库_object    Go_Rush(阿舜) @  http://ashun.cnblogs.com/  <br />

javascript 通用效果库_object    </font>

javascript 通用效果库_object</div>    

这一页挺长的,明天新开一个随笔,再把扩展的插件 size, move,zoom,color等等全部贴出来,还有一些示范代码