Recently, I started to use flex. Compared with javascript, I feel that the Timer class of as3 is very powerful. Javascript only has the setTimeout and setInternval of the nude. To implement a slightly more complex function, programmers with little background will write code in disorder. OK, no nonsense. Implement a javascript Timer.
Compared with the Timer class of as3, the function is slightly changed.
Timer2.src. js
The Code is as follows:
/**
* Timer Model
*
* @ Author rainsilence
* @ Version 2.0
*/
(Function (){
/**
* TimerEvent constructor
*
* @ Param type event type
* @ Param bubbles: whether the ticket is issued
* @ Param cancelable: can be canceled?
*/
TimerEvent = function (type, bubbles, cancelable ){
This. type = type;
This. bubbles = bubbles;
This. cancelable = cancelable;
};
/**
* Event time Event Declaration
*
* @ Event TIMER
* @ Event TIMER_COMPLETE
*/
Extend (TimerEvent ,{
TIMER: "timer ",
TIMER_COMPLETE: "timerComplete"
});
/**
* Event Method
*
* @ Method toString
*/
Extend (TimerEvent. prototype ,{
ToString: function (){
Return "[TimerEvent type =" + this. type +
"Bubbles =" + this. bubbles +
"Cancelable =" + this. cancelable + "]";
}
});
/**
* Extend extension class, object attributes or methods
*
* @ Param target object
* @ Param methods it may be more appropriate to change this parameter to param, indicating that the object carrying the object and the object of the method are used for target extension.
*/
Function extend (target, methods ){
If (! Target ){
Target = {};
}
For (var prop in methods ){
Target [prop] = methods [prop];
}
Return target;
}
/**
* Timer Constructor
*
* @ Param delay how long is the latency of the execution method handle?
* @ Param repeatCount: the number of repeated times. If this parameter is not set, the number of repeated times is unlimited.
*/
Timer = function (delay, repeatCount ){
Var listenerMap = {};
ListenerMap [TimerEvent. TIMER] = [];
ListenerMap [TimerEvent. TIMER_COMPLETE] = [];
Extend (this ,{
CurrentCount: 0,
Running: false,
Delay: delay,
RepeatCount: repeatCount,
// True: Interval, false: Timeout
RepeatType: repeatCount = null | repeatCount <1? True: false,
Handler: listenerMap,
TimerId: 0,
IsCompleted: false
});
};
// Event object initialization (this part is not implemented)
Var timerEvent = new TimerEvent (TimerEvent. TIMER, false, false );
Var timerCompleteEvent = new TimerEvent (TimerEvent. TIMER_COMPLETE, false, false );
/**
* Timer method
*
* @ Method addEventListener Add a method handle (the first two parameters are required, and the last parameter is optional)
* @ Method removeEventListener remove a method handle
* @ Method start Timer
* @ Method stop end Timer
* @ Method reset timer
*/
Extend (Timer. prototype ,{
AddEventListener: function (type, listener, useCapture ){
If (type = TimerEvent. TIMER | type = TimerEvent. TIMER_COMPLETE ){
If (! Listener ){
Alert ("Listener is null ");
}
If (useCapture = true ){
This. handler [type]. splice (0, 0, [listener]);
} Else {
This. handler [type]. push (listener );
}
}
},
RemoveEventListener: function (type, listener ){
If (type = TimerEvent. TIMER | type = TimerEvent. TIMER_COMPLETE ){
If (! Listener ){
This. handler [type] = [];
} Else {
Var listeners = this. handler [type];
For (var index = 0; index <listeners. length; index ++ ){
If (listeners [index] = listener ){
Listeners. splice (index, 1 );
Break;
}
}
}
}
},
Start: function (){
Var timerThis = this;
If (this. running = true | this. isCompleted ){
Return;
}
If (this. handler [TimerEvent. TIMER]. length = 0 &&
This. handler [TimerEvent. TIMER_COMPLETE]. length = 0 ){
Alert ("No Function ");
Return;
}
If (this. repeatType ){
This. timerId = setInterval (function (){
DispachListener (timerThis. handler [TimerEvent. TIMER], timerEvent );
TimerThis. currentCount ++;
}, This. delay );
} Else {
This. timerId = setTimeout (function () {delayExecute (timerThis. handler [TimerEvent. TIMER]) ;}, this. delay );
}
This. running = true;
Function delayExecute (listeners ){
DispachListener (listeners, timerEvent );
TimerThis. currentCount ++;
If (timerThis. currentCount <timerThis. repeatCount ){
If (timerThis. running ){
TimerThis. timerId = setTimeout (function () {delayExecute (listeners) ;}, timerThis. delay );
}
} Else {
TimerThis. running = false;
}
If (timerThis. running = false ){
If (! TimerThis. isCompleted ){
DispachListener (timerThis. handler [TimerEvent. TIMER_COMPLETE], timerCompleteEvent );
}
TimerThis. isCompleted = true;
}
}
Function dispachListener (listeners, event ){
For (var prop in listeners ){
Listeners [prop] (event );
}
}
},
Stop: function (){
This. running = false;
If (this. timerId = null ){
Return;
}
If (this. repeatType ){
ClearInterval (this. timerId );
} Else {
ClearTimeout (this. timerId );
}
If (! This. isCompleted ){
Var listeners = this. handler [TimerEvent. TIMER_COMPLETE];
For (var prop in listeners ){
Listeners [prop] (timerCompleteEvent );
}
}
This. isCompleted = true;
},
Reset: function (){
This. currentCount = 0;
This. isCompleted = false;
}
});
})();
Next, let's test it. Have you ever seen the Scroll display on Sina? It's written in setTimeout. It's really called a ox cross ...... Rebuild with Timer, easy to understand
TimerTest.html
The Code is as follows:
Insert title here