Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> clearTimeout w klasie nie przestaje wywoływać metody
starach
post
Post #1





Grupa: Zarejestrowani
Postów: 999
Pomógł: 30
Dołączył: 14.01.2007
Skąd: wiesz ?

Ostrzeżenie: (0%)
-----


Napisałem sobie klasę Counter która ma służyć za prosty licznik który wykorzystam przy wywołaniach AJAX'a.
Niestety z jakiegoś niewiadomego mi powodu wewnętrzna metoda sprawdzająca nie wyłącza mi licznika. Z zewnątrz mogę to zrobić, ale z wew. klasy nie.

Kod
function Counter()
{
    this.jump = 1;
    this.meter = 0;
    this.timeout = 100;
    this.count_to = null;
    this.evt_func = null;
    this.task_pointer = null;
    var ths = this
    
    this.start = function()
    {
        this.meter += this.jump;
        if(this.evt_func !== null)
        {
            setTimeout(this.evt_func, 0);
        }
        if(this.count_to !== null && this.count_to == this.meter)
        {
            this.stop();
        }
        this.task_pointer = setTimeout(function(){ ths.start(); }, this.timeout);
    }
    this.stop = function()
    {
        $('span#test2').html(this.meter);
        clearTimeout(this.task_pointer);
    }
    this.eventRegister = function($fn)
    {
        if(!jQuery.isFunction($fn)) {
            alert('Paremeter incorrect given for Counter::eventRegister');
        } else {
            this.evt_func = $fn;
        }
    }
}

$Counter = new Counter();
$Counter.meter = 0;
$Counter.count_to = 20;
$Counter.eventRegister(function($Counter)
{
    $('span#test').html($Counter.meter);
});
$Counter.start();

$Counter.meter może nie działać bo kod przepisałem z mojej klasy obsługi wywołania AJAX która jest statyczna zmieniając function() na function($Counter) więc nie jestem pewien czy ten przykład będzie śmigać tak jak powinien. Ale u mnie $('span#test') zmienia swoją wartość co sekundę. Natomiast $('span#test2') gdy licznik dojdzie do 20. Niestety nie zatrzymuje się na nich tylko jedzie dalej do usranej śmierci... Z kolei jeśli wywołam metodę stop z zewnątrz klasy to licznik przestaje dalej lecieć. Co może być przyczyną?

p.s.
Tak przy okazji się zapytam. Wiecie może jak wywołanie 'zdarzenia licznika' setTimeout(this.evt_func, 0); zastąpić czym nie wykorzystującym setTimeout? Chodzi mi o to jak mam to w inny sposób wywołać.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
starach
post
Post #2





Grupa: Zarejestrowani
Postów: 999
Pomógł: 30
Dołączył: 14.01.2007
Skąd: wiesz ?

Ostrzeżenie: (0%)
-----


A ja przeoczyłem fakt że tępak ze mnie...

No oczywiście że to jest logiczne. Dziękuję bardzo pewnie gdybym sam szukał przyczyny nie znalazłbym prędko... :|

edit>
Dałem 3 razy pomógł mam nadzieję że nie przesadziłem.

Jeszcze jakbyście mi powiedzieli dlaczego należy używać setInterval zamiast setTimeout.

edit>>
Ok już znalazłem.
Cytat
What is setTimeout():

It is a function that can execute other javascript statement AFTER x interval. The interval unit is millisecond.

Syntax:

setTimeout(”do.something();”, 1000); //Execute do.something() 1 second later.

What is setInterval():

It is a function that can execute other javascript statement EVERY x interval. The interval unit is millisecond.

Syntax:

setInterval(”do.somethingElse();”, 2000); //Execute do.somethingElse() every 2 seconds.


Ten post edytował orglee 6.04.2009, 21:03:36
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 12.10.2025 - 23:27