opóźnienie javascript między wywołaniami funkcji dla każdego indeksu w tablicy [zamknięte]

Cel:Wykonaj logikę na każdym elemencie w tablicy.CzekaćX ms pomiędzy kolejną realizacją.mouseover(#slider) wstrzymuje opóźnienie - jeśli opóźnienie = 1000 ms i minęło 300 ms,mouseout(#slider) spowodowałoby wznowienie odliczania pozostałych 700 ms opóźnienia.Po wykonaniu ostatniego elementu zapętl się ponownie, aby zrobić to ponownie - na zawsze.

Oto wizualne wyjaśnienie:

var = s Array(1,2,3)

var x = s[1];   //get first element   
console.log(x); //do something to it
wait();         //START wait timer 1000ms

//------------> timer : 300ms
//------------> user  : mouseover (#slider) : pause timer
//------------> user  : waited 5000ms
//------------> user  : mouseout  (#slider) : resume timer
//------------> timer : 300ms --> still 700ms to go!
//------------> timer : 500ms
//------------> user  : mouseover (#slider) : pause timer
//------------> user  : waited 10000ms
//------------> user  : mouseout  (#slider) : resume timer
//------------> timer : 500ms --> still 500ms to go!

var x = s[2];   //get second element   
console.log(x); //do something to it
wait();         //START wait timer 1000ms

//------------> timer : 200ms
//------------> user  : mouseover (#slider) : pause timer
//------------> user  : onclick   (.slideButton1) : change index of array and clear timer
//------------> user  : waited 6000ms
//------------> user  : mouseout  (#slider) : resume timer
//------------> timer : 0ms --> still 1000ms to go!

var x = s[1];   //get first element   ( index was changed by clicking button )
console.log(x); //do something to it
wait();         //START wait timer 1000ms

// ... s[2] ... s[3] ...
//theres nothing else in the array, lets start back from s[1] again!
Rozwiązania:

jQuery:

http://jsfiddle.net/zGd8a/8/

To rozwiązanie pochodzi z pokrewnegosłupek. Oficjalne źródło tej wtyczki można znaleźćtutaj.

Rodzimy JS:

http://jsfiddle.net/SyTFZ/4/

ToOdpowiedź przezAadit M Shah był naprawdę pomocny. Wchodzi także w szczegółyDelta Timing i jak może to być przydatne w podobnych przypadkach.

Nowy cel:

Wykreśl jedną z tych metod, aby umożliwić używanie innych rzeczy.

questionAnswers(3)

yourAnswerToTheQuestion