DevProTalk

Forumi IT profesionalaca
web development, web design, e-business, SEO


Idite nazad   DevProTalk > Web development i web aplikacije > (X)HTML, JavaScript, DHTML, XML, CSS
Želite da se reklamirate ekskluzivno na ovoj poziciji? Javite se

(X)HTML, JavaScript, DHTML, XML, CSS Client scripting tehnologije, Dynamic HTML, Cascading Stylesheets, XML i standardi

Odgovori
 
Alati teme Način prikaza
Staro 08. 11. 2007.   #1
dee
Domagoj Horvat
Expert
 
Avatar dee
 
Datum učlanjenja: 24.07.2006
Lokacija: Zagreb
Poruke: 502
Hvala: 22
10 "Hvala" u 8 poruka
dee is on a distinguished road
Pošaljite ICQ poruku za dee
Default javascript - setTimeout() iz objekta

imam kod otprilike ove strukture:

Kôd:
function Objekt()
{
this.funkcija1 = funkcija1;
this.funkcija2 = funkcija2;
this.nesto = "bla";
.
.
.
function funkcija1(){
.
.
.
this.funkcija2();
}

function funkcija2(){
.
.
.
setTimeout("this.funkcija2()" , 10);
}

}

var Instanca = new Objekt();
this.funkcija2() kao argument setTimeout-a ne radi. ako unutra napisem Instanca.funkcija2() tad radi. cini li mi se ili je ovo malo blesavo? (iz funkcije1, poziv this.funkcija2(); radi)
__________________
postoje ludosti bez kojih je nemoguce ljudsko dostojanstvo
dee je offline   Odgovorite uz citat
Staro 08. 11. 2007.   #2
noviKorisnik
Dejan Katašić
Wrote a book
 
Avatar noviKorisnik
 
Datum učlanjenja: 10.06.2005
Lokacija: Novi Sad
Poruke: 1.017
Hvala: 129
86 "Hvala" u 43 poruka
noviKorisnik će postati "faca" uskoro
Default

The 'this' problem
Ako napišeš 'setTimeout("this.funkcija2()" , 10);' to odlaže evaluaciju string izraza za 10 ms, kada se this iz stringa pridružuje window objektu.
noviKorisnik je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #3
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

ovo je klasican problem sa this... ovo mozes da resis sa closure-om:

Kôd:
function funkcija2(){
   var self = this;
   var closure = function(){  self.funkcija1();  };
   this.timer = window.setTimeout(closure, 10);
}
__________________
Leadership is the art of getting people to want to do what you know must be done.

Poslednja izmena od ivanhoe : 09. 11. 2007. u 02:08.
ivanhoe je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #4
dee
Domagoj Horvat
Expert
 
Avatar dee
 
Datum učlanjenja: 24.07.2006
Lokacija: Zagreb
Poruke: 502
Hvala: 22
10 "Hvala" u 8 poruka
dee is on a distinguished road
Pošaljite ICQ poruku za dee
Default

znaci, ako ispravno shvacam, point je uzeti 'onaj this' koji je unutar funkcije (a ne unutar npr. setTimeout/addEventListener argument liste) i staviti u closure jer ce tad bit vezan za konkretan objekt umjesto uz window? right?
__________________
postoje ludosti bez kojih je nemoguce ljudsko dostojanstvo
dee je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #5
noviKorisnik
Dejan Katašić
Wrote a book
 
Avatar noviKorisnik
 
Datum učlanjenja: 10.06.2005
Lokacija: Novi Sad
Poruke: 1.017
Hvala: 129
86 "Hvala" u 43 poruka
noviKorisnik će postati "faca" uskoro
Default

Izgleda da može i jednostavnije, jer je prvi argument u setTimeoutu ili string za evaluaciju (koja se vrši pri isteku čekanja) ili referenca na funkciju (koja postoji u trenutku zadavanja tajmauta), pa ako proslediš referencu na funkciju nema frke - evo test -
Kôd:
funkcija2 = function () {
    alert ('ovaj nam ne treba ovaj put, sorry');
}
objekat = {
    funkcija1:  function () {
        setTimeout (this.funkcija2, 10);
    },
    funkcija2:  function () {
        alert ('uspeo poziv, bravo');
    }
}
objekat.funkcija1 ();
Znači, samo referenca umesto stringa.
noviKorisnik je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #6
LiquidBrain
Milan Cvejic
Wrote a book
 
Avatar LiquidBrain
 
Datum učlanjenja: 05.09.2006
Lokacija: Beograd
Poruke: 1.241
Hvala: 32
73 "Hvala" u 56 poruka
LiquidBrain će postati "faca" uskoro
Pošaljite poruku preko Yahoo za LiquidBrain
Default

Ovaj javascript je postao preterano ruzan...
__________________
http://weevify.com
LiquidBrain je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #7
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

ovo je klasican javascript, samo se malo stil pisanja koda promenio... umesto objekat.prototype.neka_funkcija sad je uobicajeno da se koristi notacija kao za asocijativni niz
__________________
Leadership is the art of getting people to want to do what you know must be done.
ivanhoe je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #8
LiquidBrain
Milan Cvejic
Wrote a book
 
Avatar LiquidBrain
 
Datum učlanjenja: 05.09.2006
Lokacija: Beograd
Poruke: 1.241
Hvala: 32
73 "Hvala" u 56 poruka
LiquidBrain će postati "faca" uskoro
Pošaljite poruku preko Yahoo za LiquidBrain
Default

Off Topic:
Ma znam da je klasican js, samo sam konstatovao na glas... zasto ljudi vishe ne koriste:

Kôd:
move ax,0xFFFFFFFF;
cmp al, 0;
jne nije_isto;
mnogo je jednostavnije bilo... sada se nekako sve zakomplikovalo... Long Live Assembly

:P
__________________
http://weevify.com
LiquidBrain je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #9
bluesman
Goran Pilipović
Sir Write-a-Lot
 
Avatar bluesman
 
Datum učlanjenja: 18.05.2005
Lokacija: Beograd
Poruke: 5.450
Hvala: 288
1.247 "Hvala" u 446 poruka
bluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušati
Pošaljite ICQ poruku za bluesman
Default

Off Topic:
Citat:
Originalno napisao LiquidBrain Pogledajte poruku
Ovaj javascript je postao preterano ruzan...
Zato što ga preterano komplikuju Osim xmlHttprequest, javascript je skoro isti kao 1996 godine... tada nije bilo fensi prototype... Prave od toga ono što on nije, ali to je neka druga priča... da ne kvarimo temu.
__________________
Goran Pilipović a.k.a. Ugly Fingers Bradley f.k.a. bluesman
I don't always know what I'm talking about but I know I'm right!
bluesman je offline   Odgovorite uz citat
Staro 09. 11. 2007.   #10
dee
Domagoj Horvat
Expert
 
Avatar dee
 
Datum učlanjenja: 24.07.2006
Lokacija: Zagreb
Poruke: 502
Hvala: 22
10 "Hvala" u 8 poruka
dee is on a distinguished road
Pošaljite ICQ poruku za dee
Default

Citat:
Originalno napisao noviKorisnik Pogledajte poruku
Izgleda da može i jednostavnije, jer je prvi argument u setTimeoutu ili string za evaluaciju (koja se vrši pri isteku čekanja) ili referenca na funkciju (koja postoji u trenutku zadavanja tajmauta), pa ako proslediš referencu na funkciju nema frke - evo test -
Kôd:
funkcija2 = function () {
    alert ('ovaj nam ne treba ovaj put, sorry');
}
objekat = {
    funkcija1:  function () {
        setTimeout (this.funkcija2, 10);
    },
    funkcija2:  function () {
        alert ('uspeo poziv, bravo');
    }
}
objekat.funkcija1 ();
Znači, samo referenca umesto stringa.
ali izgleda da rekurzija ne radi.... naime, setTimeout (this.funkcija2, 10); unutar objekt.funkcija2 opet vraca globalnu funkciju2
__________________
postoje ludosti bez kojih je nemoguce ljudsko dostojanstvo

Poslednja izmena od dee : 09. 11. 2007. u 19:35.
dee je offline   Odgovorite uz citat
Odgovori



Pravila pisanja
Možete ne započinjati nove teme
Možete ne slati odgovore
Možete ne slati priloge
Možete ne izmeniti svoje poruke
vB kôd je Uključen
Smajliji su Uključen
[IMG] kod je Uključen
HTML kôd je Isključen
Pogledajte forum

Slične teme
Tema Početna poruka teme Forum Odgovori Poslednja poruka
PHP + Mysql + javascript PeTkO Sva početnička pitanja 3 29. 02. 2008. 18:48
JavaScript watermark za IE6??? Croll (X)HTML, JavaScript, DHTML, XML, CSS 2 26. 12. 2007. 11:27
Javascript ORM kodi (X)HTML, JavaScript, DHTML, XML, CSS 2 10. 07. 2007. 12:17
Inlining objekta, sve sem Opere ne podrzava standard! bojan_bozovic (X)HTML, JavaScript, DHTML, XML, CSS 14 07. 01. 2007. 21:52
javascript 3D ivanhoe Opušteno 2 03. 11. 2006. 13:25


Vreme je GMT +2. Trenutno vreme je 21:48.


Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.
Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.