Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [JavaScript][AJAX]Kod nie wykonuje sie za kazdym razem, Dlaczego tak sie dzieje?
Twist
post 25.07.2012, 16:53:22
Post #1





Grupa: Zarejestrowani
Postów: 174
Pomógł: 11
Dołączył: 12.10.2008
Skąd: Dublin

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


Mamy nastepujacy kod:
Najpierw wywouluej funkcje, ktora laduej reszte

  1. $("a#showA").click(function () {
  2. getHotelInfo(apiKey);
  3. });


I po kolei:

  1. function getHotelInfo(yourAPIKey) {
  2. var enquiry = "XXX; //tutaj url do wykonania
  3. //alert(enquiry);
  4. $.ajax({
  5. url: enquiry,
  6. type: 'GET',
  7. dataType: "jsonp",
  8. jsonp: "callback",
  9. jsonpCallback: "jsonpCallback2",
  10. complete: function (response, responseCode) {
  11. },
  12. success: function (json) {
  13. $.each(json.Contracts, function (index, contract) {
  14. getAvailability(yourAPIKey, contract.ContractCode, startDate, endDate);
  15. getRates(yourAPIKey, contract.ContractCode, startDate, endDate);
  16. alert(contract.ContractCode + " - done "); // <---- O TYM MOWIE
  17. });
  18. }
  19. });
  20. }


Funkcje getAvailability i getRates - powinny sie wekonac dwukrotnie. I tak jest - wszystko super. Problem polega na tym, że gdy usune alert to te funkcje wykonuje sie tyko raz.

oto te 2 funkcje oraz tzrecia, ktorej obie uzywaja:

  1. function populateValues(Type, Contractname, RoomType, Date, val) {
  2. $("input#" + Type + "_IE-ORK-IN-32966275_" + Contractname + "_" + RoomType + "_" + Date).val(val);
  3. // alert("input#" + Type + "_" + Contractname + "_" + RoomType + "_" + Date + " -> " + val);
  4. }
  5.  
  6. function getRates(yourAPIKey, contractCode, startDate, endDate) {
  7. var ratesEnquiry = "URL + yourAPIKey + "&contractCode=" + contractCode + "&startDate=" + startDate + "&endDate=" + endDate;
  8.  
  9. $.ajax({
  10. url: ratesEnquiry,
  11. type: 'GET',
  12. dataType: "jsonp",
  13. jsonp: "callback",
  14. jsonpCallback: "jsonpCallback3",
  15. complete: function (response, responseCode) {
  16. //console.log(response); console.log(responseCode);
  17. //alert("complete");
  18. },
  19. success: function (json) {
  20. $.each(json, function (index, value) {
  21. // populateValues("rate", this.ContractCode, this.RoomTypeCode, this.Date.substr(0, 10), this.RoomPrice);
  22. // populateValues("hrate", this.ContractCode, this.RoomTypeCode, this.Date.substr(0, 10), this.RoomPrice);
  23. });
  24. }
  25. });
  26. }
  27.  
  28. function getAvailability(yourAPIKey, contractCode, startDate, endDate) {
  29. var availabilityEnquiry = "[i]URL[/i]" + yourAPIKey + "&contractCode=" + contractCode + "&startDate=" + startDate + "&endDate=" + endDate;
  30. $.ajax({
  31. url: availabilityEnquiry,
  32. type: 'GET',
  33. dataType: "jsonp",
  34. jsonp: "callback",
  35. jsonpCallback: "jsonpCallback",
  36. complete: function (response, responseCode) {
  37. //console.log(response); console.log(responseCode);
  38. //alert("complete");
  39. },
  40. success: function (json) {
  41. $.each(json, function (index, value) {
  42. //populateAvailability(this.Date.substr(0, 10), this.RoomTypeCode, this.ContractCode, this.Quantity);
  43. populateValues("avail", this.ContractCode, this.RoomTypeCode, this.Date.substr(0, 10), this.Quantity);
  44. populateValues("havail", this.ContractCode, this.RoomTypeCode, this.Date.substr(0, 10), this.Quantity);
  45. });
  46. }
  47. });
  48. }



Powiedzialby, że to dziwne. Ale nauczylem sie, ze jak coś jest dziwne, to znaczy, ze tego nie rozumiem. Moze mi ktos wytlumaczy?
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 9)
lobopol
post 25.07.2012, 17:05:53
Post #2





Grupa: Zarejestrowani
Postów: 1 729
Pomógł: 346
Dołączył: 4.04.2009

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


[JAVASCRIPT] pobierz, plaintext
  1. $("a#showA").click(function (e) {
  2. e.preventDefault();
  3. getHotelInfo(apiKey);
  4. });
[JAVASCRIPT] pobierz, plaintext

Strona ci się zapewne przeładowywała


--------------------
Go to the top of the page
+Quote Post
Twist
post 26.07.2012, 09:23:57
Post #3





Grupa: Zarejestrowani
Postów: 174
Pomógł: 11
Dołączył: 12.10.2008
Skąd: Dublin

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


Dzieki za pomoc, ale to jednak nie to, poniewaz html wyglada tak:
  1. <a id="showA">Show Availibility</a>


Zastanawia mnie, dlaczego dodanie alertu w tamtym each sprawa ze wsyztsko dziala super. moze to przez opoznienie?
Generlanie mozna tot ka zobrazowac:

  1. Pobieram nazwe hotelu uzywajac API-key
  2. Pobieram ilsoc kontraktow (w tym przypadku 2)
  3. Gdy pobiore, to dla kazdego kontraktu wykonuej dwa zapytania do API - getAvailability i getRates
  4. Obie uzywaja populateValues, aby wypisac pobrane wartosci


Moje rozumowanie jest takie, ze zapytanie dziala wolno i przez to nia zdazy pobrac potrzebnych informacji i przekazac dalej. Wprawadzenia alertu stopouje na moment skrypt i daje doatkowy czas na API Callback. Dodam, ze ta sytuacja ma miejsce w firefoxie. W chromie alert nie robi roznicy.

Go to the top of the page
+Quote Post
erix
post 26.07.2012, 09:29:42
Post #4





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




Wcale nie chodzi o "za wolno". Chodzi o asynchroniczność: http://eriz.pcinside.pl/weblog/ajax-w-jque...script-218.html


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
wNogachSpisz
post 26.07.2012, 10:26:43
Post #5





Grupa: Zarejestrowani
Postów: 1 233
Pomógł: 87
Dołączył: 6.03.2009

Ostrzeżenie: (40%)
XX---


Jeśli rozmawiamy o sychronizacji w połączeniu z DataType: JSONP, to warto pamiętać że:

Cytat
Cross-domain requests and dataType: "jsonp" requests do not support synchronous operation.
Go to the top of the page
+Quote Post
Twist
post 26.07.2012, 10:35:49
Post #6





Grupa: Zarejestrowani
Postów: 174
Pomógł: 11
Dołączył: 12.10.2008
Skąd: Dublin

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


No to teraz sie troche pogubilem. Wydaje mi sie, ze rozumiemdlaczego nie dziala, ale nie wiem jak to naprawic.
- async: false - nie robi roznicy (to chyba wynika z tego co napisal wNogachSpisz)

Mysle, ze moznaby sztucznie opozniec wykonanie funkcji, ale to ma sporo wad...
Go to the top of the page
+Quote Post
erix
post 26.07.2012, 10:41:22
Post #7





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




Cytat
Mysle, ze moznaby sztucznie opozniec wykonanie funkcji, ale to ma sporo wad...

W notce pisałem o callbackach.


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
Twist
post 26.07.2012, 16:35:54
Post #8





Grupa: Zarejestrowani
Postów: 174
Pomógł: 11
Dołączył: 12.10.2008
Skąd: Dublin

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


Przyznam, ze dalej nie bardzo wiem jak to zastosowac. Dopiero sie wdrazamw AJAX i wygląda to troche skomplikowanie.
Go to the top of the page
+Quote Post
erix
post 27.07.2012, 08:59:11
Post #9





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




Popróbuj, wtedy najlepiej się nauczysz. [;


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
Twist
post 2.08.2012, 13:13:23
Post #10





Grupa: Zarejestrowani
Postów: 174
Pomógł: 11
Dołączył: 12.10.2008
Skąd: Dublin

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


EDIT: ROZWIAZANE
Zasugerowałem się tym co erix napisał i straciłem sporo czasu na rpzerabianie skryptu. Okazało się, że wsyztskei sposoby, ktory robiłem były dobre i problem nie był wcale w asycnhroniczności a w nazwie jsoncallback. Wystarczylo to wyrzucić i wszystkie wersje śmigają świetnie.

Poniezej oryginalna tresc postu.

Zrobiłem coś takiego:
  1.  
  2.  
  3. $("a#showA").click(function (e) {
  4. e.preventDefault();
  5. chceckResults(callAPI(apiKey));
  6. });
  7.  



  1. var Count = 0;
  2. var ContractsArray = new Array();
  3.  
  4.  
  5. function callAPI(yourAPIKey){
  6. var enquiry = URL + yourAPIKey;
  7. //alert(enquiry);
  8. $.ajax({
  9. url: enquiry,
  10. type: 'GET',
  11. dataType: "jsonp",
  12. jsonp: "callback",
  13. jsonpCallback: "jsonpCallback2",
  14. complete: function (response, responseCode) {
  15. },
  16. success: function (json) {
  17. $.each(json.Contracts, function (index, contract) {
  18. // alert("Count before increament : " + Count);
  19. // alert(contract.ContractCode);
  20. ContractsArray[Count] = contract.ContractCode;
  21.  
  22. // alert("Count after increament : " + Count);
  23. // alert("ContractsArray[Count]: " + ContractsArray[Count]);
  24. Count++;
  25.  
  26. });
  27. }
  28. });
  29. }
  30.  
  31. function chceckResults(){
  32. alert("Count value in chceckResults : " + Count);
  33. for(var i = 0; i <= Count; i++){
  34. alert("ContractsArray[" + i + "]: " + ContractsArray[i]);
  35. }
  36. }


Chce, zeby chceckResults wykonala sie dopiero, gdy wykona sie callAPI. jednak dalej działa tka jak wczesniej. Jak to powinno być zeby bylo dobrze?



Ten post edytował Twist 2.08.2012, 13:14:05
Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 24.07.2025 - 16:08