Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> js, rekurencje, liczenie pomocy!
daniofantasy
post
Post #1





Grupa: Zarejestrowani
Postów: 30
Pomógł: 1
Dołączył: 14.06.2007
Skąd: Chesterfield UK

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


Witam,

Mam takie cudo:


  1. var ImgFader = function(FadeDelay,TimeDelay,x,aImages1,aImages2,aImages3,DOMElement,FirstTimeStart) {
  2.  
  3. var FirstFader = $(DOMElement[0]);
  4. var SecondFader = $(DOMElement[1]);
  5. var ThirdFader = $(DOMElement[2]);
  6.  
  7. if (x==4) {
  8. x=1;
  9. }
  10.  
  11. var OldTimeDelay = TimeDelay;
  12.  
  13. if (FirstTimeStart) {
  14. TimeDelay = 0;
  15. }
  16.  
  17. setTimeout(function() {
  18. FirstFader.fadeOut(FadeDelay);
  19. SecondFader.fadeOut(FadeDelay);
  20. ThirdFader.fadeOut(FadeDelay);
  21. setTimeout(function() {
  22. FirstFader.css('background','url('+aImages1[x-2]+')');
  23. SecondFader.css('background','url('+aImages2[x-2]+')');
  24. ThirdFader.css('background','url('+aImages3[x-2]+')');
  25. }, FadeDelay);
  26.  
  27. FirstFader.fadeIn(FadeDelay);
  28. SecondFader.fadeIn(FadeDelay);
  29. ThirdFader.fadeIn(FadeDelay);
  30. x++;
  31. ImgFader(FadeDelay,OldTimeDelay,x,aImages1,aImages2,aImages3,DOMElement,false);
  32. }, TimeDelay);
  33. };
  34.  
  35. $(document).ready( function (){
  36. var images1 = new Array('images/Img1_1.jpg','images/Img2_1.jpg','images/Img3_1.jpg')
  37. var images2 = new Array('images/Img1_2.jpg','images/Img2_2.jpg','images/Img3_2.jpg')
  38. var images3 = new Array('images/Img1_3.jpg','images/Img2_3.jpg','images/Img3_3.jpg')
  39. var DOMElements = new Array('#Fader1','#Fader2','#Fader3');
  40. ImgFader(500,5000,1,images1,images2,images3,DOMElements,true);
  41. });


i teraz jak po kodzie :


if (x==4) {
x=1;
}

wrzuce alerta, to przy każdym jednorazowym wywołaniu funkcji zamiast mi ładnie wyświetlić, że x=1 albo x=2 albo x=3, czego bym się spodziewał, ten zakichany js wali mi alertami z każdym kolejnym argumentem funkcji z którym rekurencja była wcześniej wywołana,

przez to nie mogę po tym if-ie zrobić ślicznego:

if (x == 1) {
...moje instrukcje...
}
Od razu zaznaczam, że o js mam tylko blade pojęcie - i tak - zdaję sobie sprawę, że powyżej cytowany kod jest daleki od dobrego webowego rzemieślnictwa - prosiłbym tylko osoby znające się na tym o pomoc w zrozumieniu o co chodzi - dlaczego mój x w tej funkcji wygląda tak: 123123123123 zamiast 1 lub 2 lub 3

Bo podejrzewam, że to coś nie tak z inkrementacją - bo dlaczego x które jest równe 1, zwiększone o 1 daje w wyniku 12 zamiast 2... :/ ... ?

Proszę o pomoc - z góry dziękuję (IMG:style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
daniofantasy
post
Post #2





Grupa: Zarejestrowani
Postów: 30
Pomógł: 1
Dołączył: 14.06.2007
Skąd: Chesterfield UK

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


Witam, przeorganizowałem trochę kod - idąc na około i eliminując problem ze zliczaniem x-ów, obecnie wygląda to tak:

  1. var ImgFader = function(FadeDelay,TimeDelay,x,aImages1,aImages2,aImages3,DOMElement,FirstTimeStart) {
  2.  
  3. var FirstFader = $(DOMElement[0]);
  4. var SecondFader = $(DOMElement[1]);
  5. var ThirdFader = $(DOMElement[2]);
  6.  
  7. var OldTimeDelay = TimeDelay;
  8.  
  9. if (FirstTimeStart && parseInt(x) == 1) {
  10. //TimeDelay = 0;
  11. }
  12.  
  13. var Fade1 = false;
  14. var Fade2 = false;
  15. var Fade3 = false;
  16.  
  17. if (x==1) {
  18.  
  19. setTimeout(function() {
  20.  
  21. FirstFader.hover(function() {
  22. $('.Cloud1_1').fadeIn('50');
  23. Fade1 = true;
  24. },function() {
  25. Fade1 = false;
  26. $('.Cloud1_1').fadeOut('50');
  27. });
  28.  
  29. FirstFader.fadeOut(FadeDelay);
  30. SecondFader.fadeOut(FadeDelay);
  31. ThirdFader.fadeOut(FadeDelay);
  32. setTimeout(function() {
  33.  
  34. FirstFader.css('background','url('+aImages1[0]+')');
  35. SecondFader.css('background','url('+aImages2[0]+')');
  36. ThirdFader.css('background','url('+aImages3[0]+')');
  37. }, FadeDelay);
  38. FirstFader.fadeIn(FadeDelay);
  39. SecondFader.fadeIn(FadeDelay);
  40. ThirdFader.fadeIn(FadeDelay);
  41.  
  42. if (parseInt(x)==3) {
  43. x = 0;
  44. }
  45.  
  46. if (Fade1 == false && Fade2 == false && Fade3 == false) {
  47. $('.Cloud1_1').fadeOut('0');
  48. $('.Cloud1_2').fadeOut('0');
  49. $('.Cloud1_3').fadeOut('0');
  50. }
  51.  
  52. x = x + 1;
  53. ImgFader(FadeDelay,TimeDelay,parseInt(x),aImages1,aImages2,aImages3,DOMElement,false);
  54. }, TimeDelay);
  55. }
  56.  
  57. if (x==2) {
  58. setTimeout(function() {
  59. FirstFader.hover(function() {
  60. Fade2 = true;
  61. $('.Cloud1_2').fadeIn('50');
  62. },function() {
  63. Fade2 = false;
  64. $('.Cloud1_2').fadeOut('50');
  65. });
  66.  
  67. FirstFader.fadeOut(FadeDelay);
  68. SecondFader.fadeOut(FadeDelay);
  69. ThirdFader.fadeOut(FadeDelay);
  70. setTimeout(function() {
  71.  
  72. FirstFader.css('background','url('+aImages1[1]+')');
  73. SecondFader.css('background','url('+aImages2[1]+')');
  74. ThirdFader.css('background','url('+aImages3[1]+')');
  75. }, FadeDelay);
  76. FirstFader.fadeIn(FadeDelay);
  77. SecondFader.fadeIn(FadeDelay);
  78. ThirdFader.fadeIn(FadeDelay);
  79.  
  80. if (parseInt(x)==3) {
  81. x = 0;
  82. }
  83.  
  84. if (Fade1 == false && Fade2 == false && Fade3 == false) {
  85. $('.Cloud1_1').fadeOut('0');
  86. $('.Cloud1_2').fadeOut('0');
  87. $('.Cloud1_3').fadeOut('0');
  88. clearTimeout()
  89. }
  90.  
  91. x = x + 1;
  92. ImgFader(FadeDelay,TimeDelay,parseInt(x),aImages1,aImages2,aImages3,DOMElement,false);
  93. }, TimeDelay);
  94. }
  95.  
  96. if (x==3) {
  97. setTimeout(function() {
  98.  
  99. FirstFader.hover(function() {
  100. Fade3 = true;
  101. $('.Cloud1_3').fadeIn('50');
  102. },function() {
  103. Fade3 = false;
  104. $('.Cloud1_3').fadeOut('50');
  105. clearTimeout()
  106. });
  107.  
  108. FirstFader.fadeOut(FadeDelay);
  109. SecondFader.fadeOut(FadeDelay);
  110. ThirdFader.fadeOut(FadeDelay);
  111. setTimeout(function() {
  112.  
  113. FirstFader.css('background','url('+aImages1[2]+')');
  114. SecondFader.css('background','url('+aImages2[2]+')');
  115. ThirdFader.css('background','url('+aImages3[2]+')');
  116. }, FadeDelay);
  117. FirstFader.fadeIn(FadeDelay);
  118. SecondFader.fadeIn(FadeDelay);
  119. ThirdFader.fadeIn(FadeDelay);
  120.  
  121. if (parseInt(x)==3) {
  122. x = 0;
  123. }
  124.  
  125. if (Fade1 == false && Fade2 == false && Fade3 == false) {
  126. $('.Cloud1_1').fadeOut('0');
  127. $('.Cloud1_2').fadeOut('0');
  128. $('.Cloud1_3').fadeOut('0');
  129. clearTimeout()
  130. }
  131.  
  132. x = x + 1;
  133. ImgFader(FadeDelay,TimeDelay,parseInt(x),aImages1,aImages2,aImages3,DOMElement,false);
  134. }, TimeDelay);
  135. }
  136. };
  137.  
  138. $(document).ready( function (){
  139. var images1 = new Array('images/Img1_1.jpg','images/Img2_1.jpg','images/Img3_1.jpg')
  140. var images2 = new Array('images/Img1_2.jpg','images/Img2_2.jpg','images/Img3_2.jpg')
  141. var images3 = new Array('images/Img1_3.jpg','images/Img2_3.jpg','images/Img3_3.jpg')
  142. var DOMElements = new Array('#Fader1','#Fader2','#Fader3');
  143. ImgFader(500,5000,1,images1,images2,images3,DOMElements,true);
  144. });


I już było by ok, ale mam jeszcze problem z hoverem - bo przy pierwszych trzech rekurencjach wszystko jest ok i kod działa poprawnie - natomiast przy czwartej rekurencji, gdy x się zeruje i hover ma ponownie wyświetlić chmurkę 1_1, wyświetla mi chmurkę 1_3 z 3 rekurencji, gdzie x jest równe 3 - jak wyhashuję z kodu hovery i zostają same fady, to wszystko działa w 100% poprawnie - czyli zliczanie x-ów i wszystkie warunki są w porządku - wszystkie fady i cała reszta też działa (sprawdzałem też wcześniej wartości x-ów itd i wszystko w porządku - kod się nie zapętla, wykonuje się trzy razy i wraca - bez pustych przebiegów). Jedynie hovery straszą - i właśnie nie wiem o co tutaj chodzi - czy to jest jakieś cachowanie hovera z jQuery? Czy trzeba go jakoś zewnętrznie wyzerować, żeby mógł z powrotem przyjąć pierwotną wartość z pierwszej rekurencji?

Całość do podejrzenia tutaj (trzeba poczekać 5s na pierwszego fada):

prawne.home.pl/pieter

Konkretnie chodzi o ten kawałek kodu:

  1. FirstFader.hover(function() {
  2. $('.Cloud1_1').fadeIn('50');
  3. },function() {
  4. $('.Cloud1_1').fadeOut('50');
  5. });

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: 3.10.2025 - 02:03