DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   (X)HTML, JavaScript, DHTML, XML, CSS (http://www.devprotalk.com/forumdisplay.php?f=8)
-   -   jQuery - closures i callback funkcije (http://www.devprotalk.com/showthread.php?t=7565)

Marko Medojevic 04. 06. 2009. 21:21

jQuery - closures i callback funkcije
 
Ćao!

1. Na koji način postići da closures rade i u okviru callback funkcija? U primeru ispod sam prvo setovao promenljivu prom1 i promenio sam joj vrednost u okviru callback funkcije koja se nalazi u $.post. Međutim, kao rezultat alert(prom1) dobio sam "1"!

Kôd:

$(function()
{
        var prom1 = "1";
        $.post("/nekiurl/", {}, function(data)
        {
                prom1 = "2";
        });
       
        alert(prom1);
});

2. Na koji način pauzirati kod dok se ne okonča izvršenje callback funkcije, u ovom mom primeru između kraja $.post-a i alert(prom1)?

:1007:

misk0 04. 06. 2009. 21:35

2. Mislim da to ima veze sa asinhronim i sinhronim zahtjevom. Ako promjenis (negdje, ne znam na pamet gdje) da to ide sinhrono onda ces dobiti cekanje dok ne dobijes odgovor.

dee 13. 06. 2009. 13:22

Citat:

Originalno napisao mare_bj (Napišite 70204)
Ćao!

1. Na koji način postići da closures rade i u okviru callback funkcija? U primeru ispod sam prvo setovao promenljivu prom1 i promenio sam joj vrednost u okviru callback funkcije koja se nalazi u $.post. Međutim, kao rezultat alert(prom1) dobio sam "1"!

Kôd:

$(function()
{
        var prom1 = "1";
        $.post("/nekiurl/", {}, function(data)
        {
                prom1 = "2";
        });
       
        alert(prom1);
});

2. Na koji način pauzirati kod dok se ne okonča izvršenje callback funkcije, u ovom mom primeru između kraja $.post-a i alert(prom1)?

:1007:

Kako rece misk0 to ima veze sa sinhronim ili asinhronim procesiranjem skripte. Sinhrono ce cekati da dodje response i onda nastaviti, a asinhrono ce nastaviti sa izvrsavanjem od slijedece linije, a poziv callback funkcije ce se desiti asinhrono kad se vrati response.

http_request.open('GET/POST', url + parameters, true);

posljednji bool parametar je is async, dakle, flag koji govori kako ce zahtjev biti procesiran.

Medjutim, opcenito, puno je preglednije i 'ljepse' da odradis sve asinhrono. Dakle, na nekom mjestu u kodu radis request, a u callbacku radis obradu responsa jer sasvim je logicno da ono sto stigne u response postoji u okviru callbacka a ne sire. Ako ti pak to treba i negdje drugdje, onda iz callback funkcije pozivas dalje funkcije i prenosis sta trebas.

To je, uostalom, i bit AJAXa da svaki entitet u okviru DOMa ima svoju komunikaciju sa serverom bez da se petlja u scope koji je siri od njega samog.

[EDIT]

Dakle, konkretan razlog je: zahtjev ode asinhrono i treba mu neko vrijeme da se vrati response i pozove callback u kojem postavljas prom1 = "2". Medjutim, u medjuvremenu, izvrsavanje skripte je vec otislo dalje i prirodno ti dalo "1" jer u trenutku prije nego se vrati response prom1 je jos uvijek "1".

[/edit]


Vreme je GMT +2. Trenutno vreme je 18:12.

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.