Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [JavaScript][Jquery] Lista rozwijana.
cykcykacz
post 17.09.2013, 19:08:02
Post #1





Grupa: Zarejestrowani
Postów: 550
Pomógł: 9
Dołączył: 29.05.2009
Skąd: Ostrów Wielkopolski

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


Witam,
mam skrypt dzięki któremu rozwijam i zwijam listę:
[JAVASCRIPT] pobierz, plaintext
  1. $(document).ready(function(){
  2. $( '#menu > li > ul' )
  3. .hide()
  4. .click(function( e ){
  5. e.stopPropagation();
  6. });
  7. $('#menu > li').toggle(function(){
  8. $(this).find('ul').slideDown();
  9. }, function(){
  10. $( this ).find('ul').slideUp();
  11. });
  12. });
[JAVASCRIPT] pobierz, plaintext

Kod html
  1. <ul id="menu">
  2. <li><a href="#">Co nowego?</a>
  3. <ul class="active">
  4. <li><a href="#">Specjalności tygodnia</a></li>
  5. <li><a href="#">Zdjęcia z ostatniej nocy!</a></li>
  6. <li><a href="#">Komentarze użytkowników</a></li>
  7. </ul>
  8. </li>
  9. <li><a href="#">Tylko dla członków</a>
  10. <ul>
  11. <li><a href="#">Największe gwiazdy</a></li>
  12. <li><a href="#">Monitoring 24/7</a></li>
  13. </ul>
  14. </li>
  15. </li>
  16. <li><a href="#">O nas</a>
  17. <ul>
  18. <li><a href="#">Ochrona prywatności</a></li>
  19. <li><a href="#">Regulamin strony</a></li>
  20. <li><a href="#">Kontakt</a></li>
  21. </ul>
  22. </li>
  23. </ul>


Fajnie rozwija sie zwija się.
Ale nie wiem jak zrobić żeby klikając na jedno drzewo reszta list była zwinięta?

Rozumiecie o co chodzi obecnie działa tak, klikam na "Co nowego?" lista rozwija się następnie klikam na "Tylko dla członków" lista rozwija się i mam dwie rozwinięte listy.
A chcę aby tylko jedna lista była rozwinięta. Czyli klikając na "Tylko dla członków" lista która wcześniej była rozwinięta "Co nowego?" zwineła się.
Go to the top of the page
+Quote Post
kropamk
post 17.09.2013, 19:25:25
Post #2





Grupa: Zarejestrowani
Postów: 156
Pomógł: 12
Dołączył: 30.11.2011
Skąd: Gdańsk

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


Nie lepiej tak smile.gif ?

  1. $("#menu > li").click(function() {
  2. $(this).find("ul").slideToggle("slow");
  3. });
  4. </script>
Go to the top of the page
+Quote Post
cykcykacz
post 17.09.2013, 19:42:53
Post #3





Grupa: Zarejestrowani
Postów: 550
Pomógł: 9
Dołączył: 29.05.2009
Skąd: Ostrów Wielkopolski

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


nie działa.
Go to the top of the page
+Quote Post
kropamk
post 17.09.2013, 19:54:18
Post #4





Grupa: Zarejestrowani
Postów: 156
Pomógł: 12
Dołączył: 30.11.2011
Skąd: Gdańsk

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


nie działa po pewnie nie dałeś stylu jeszcze wink.gif

o to i on:
  1. <style type="text/css">
  2. #menu ul { display: none;}
  3. </style>
Go to the top of the page
+Quote Post
cykcykacz
post 17.09.2013, 21:29:40
Post #5





Grupa: Zarejestrowani
Postów: 550
Pomógł: 9
Dołączył: 29.05.2009
Skąd: Ostrów Wielkopolski

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


Nie nie działa tutaj mam link do mojego przykładu http://jsfiddle.net/cykcykacz/tAUS7/3/ próbowałem dodać tak jak piszesz ale nie wypaliło.
Go to the top of the page
+Quote Post
kropamk
post 17.09.2013, 22:40:45
Post #6





Grupa: Zarejestrowani
Postów: 156
Pomógł: 12
Dołączył: 30.11.2011
Skąd: Gdańsk

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


Nie wiem jak Tobie ale u mnie działa ten skrypt nawet na jsfiddle. Używam chrome. I to jest Twój skrypt.

Zerknij na mój - działa.

http://jsfiddle.net/Ms3SG/

Ten post edytował kropamk 17.09.2013, 22:53:23
Go to the top of the page
+Quote Post
cykcykacz
post 18.09.2013, 09:40:50
Post #7





Grupa: Zarejestrowani
Postów: 550
Pomógł: 9
Dołączył: 29.05.2009
Skąd: Ostrów Wielkopolski

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


Tak działa ale chyba źle wytłumaczyłem jak chciał bym żeby działał.
Są tam 3 listy i możemy każdą rozwinąć a ja chcę widzieć tylko jedną rozwiniętą resztę schowanych.
Go to the top of the page
+Quote Post
zbychoCom
post 18.09.2013, 11:08:29
Post #8





Grupa: Zarejestrowani
Postów: 55
Pomógł: 9
Dołączył: 7.04.2011

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


Chyba chodzi Ci o to: http://ferrante.pl/examples/jquery/jQuery_3a.html
Go to the top of the page
+Quote Post
nospor
post 18.09.2013, 11:14:32
Post #9





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




No to poprostu chowaj sasiadow.

http://jsfiddle.net/Ms3SG/1/


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

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
cykcykacz
post 18.09.2013, 12:58:19
Post #10





Grupa: Zarejestrowani
Postów: 550
Pomógł: 9
Dołączył: 29.05.2009
Skąd: Ostrów Wielkopolski

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


Ja znalazłem takie rozwiąznie w google. Wasze też są fajne ale mi odpowiada to bardziej:
[JAVASCRIPT] pobierz, plaintext
  1. <script type="text/javascript">
  2. $(document).ready(function () {
  3. $("#nav li:has(ul)").click(function (event) {
  4. if (this == event.target) {
  5. $(this).toggleClass('clicked').children('ul').slideToggle();
  6. $(this).find('li:has(ul)').removeClass('clicked').find("ul").slideUp();
  7. $(this).siblings().removeClass('clicked').find("ul").slideUp();
  8. }
  9. }).addClass('has_ul');
  10. });
  11. </script>
[JAVASCRIPT] pobierz, plaintext

Kod
<style type="text/css">
#nav {font: bold 12px/25px arial, sans-serif;}
#nav ul {display:none;}
</style>


Ten post edytował cykcykacz 18.09.2013, 12:59:05
Go to the top of the page
+Quote Post
slash83
post 29.07.2014, 08:44:07
Post #11





Grupa: Zarejestrowani
Postów: 3
Pomógł: 0
Dołączył: 12.04.2004

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


Witam serdecznie!

Zastosowałem rozwiązanie zaprezentowane przez uzytkownika 'nospor', działa to pięknie, ładnie, kod prosty i zrozumiały. Nioestety potrzebuję zrobić troszkę inny efekt.
Otóż przy rozwinięciu jednej listy potrzebowałbym aby zwijały się poprzednik, ale dodatkowo pozostałe nagłówki list. To nie było trudne bo zamiast:

Kod
$("#menu > li").click(function() {
            $(this).siblings().find('ul').hide();
            $(this).find("ul").slideToggle("slow");
        });


wystarczy dać:

Kod
$("#menu > li").click(function() {
            $(this).siblings().hide();
            $(this).find("ul").slideToggle("slow");
        });


Ale teraz przy zwijaniu tej konkretnej listy chciałbym aby pojawiły sie nagłówki również wszystkich pozostałych.

Kombinuję, kombinuję i już pomysłu nie mam na to.

Pozdrawiam
Darek W.

Ten post edytował slash83 29.07.2014, 08:44:55
Go to the top of the page
+Quote Post
nospor
post 29.07.2014, 09:46:43
Post #12





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




Czytam raz, czytam drugi raz i nic... nie kumam w ogole co chcesz zrobic. Jakie naglowki? W kodzie co masz u mnie jedne sie chowają inne sie pojawiają. O to chodzi.
A to co ty chcesz zrobic to nie rozumiem jak to ma dzialać


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

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
slash83
post 29.07.2014, 10:25:20
Post #13





Grupa: Zarejestrowani
Postów: 3
Pomógł: 0
Dołączył: 12.04.2004

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


Witam!

Faktycznie - strasznie tez opis zagmatwałem, może poniżej napiszę jak teraz działa skrypt i jakbym potrzebował by dział (na przykładzie wcześniej przytoczonej listy - czyli:

  1. <ul id="menu">
  2. <li><a href="#">Co nowego?</a>
  3. <ul class="active">
  4. <li><a href="#">Specjalności tygodnia</a></li>
  5. <li><a href="#">Zdjęcia z ostatniej nocy!</a></li>
  6. <li><a href="#">Komentarze użytkowników</a></li>
  7. </ul>
  8. </li>
  9. <li><a href="#">Tylko dla członków</a>
  10. <ul>
  11. <li><a href="#">Największe gwiazdy</a></li>
  12. <li><a href="#">Monitoring 24/7</a></li>
  13. </ul>
  14. </li>
  15. </li>
  16. <li><a href="#">O nas</a>
  17. <ul>
  18. <li><a href="#">Ochrona prywatności</a></li>
  19. <li><a href="#">Regulamin strony</a></li>
  20. <li><a href="#">Kontakt</a></li>
  21. </ul>
  22. </li>
  23. </ul>



Pierwotnie wszystkie listy są schowane - widzimy więc:

- Co nowego
- Tylko dla członków
- O nas

po kliknięciu na "Tylko dla członków" lista wygląda tak:

- Co nowego
- Tylko dla członków
---Największe gwiazdy
---Monitoring 24/7
- O nas

a ja chciałem by wyglądała tak:
-Tylko dla członków
---Największe gwiazdy
---Monitoring 24/7

"Co nowego" oraz "O nas" miały sie schować. Taki efekt uzyskuje się po usunięciu z $(this).siblings().find('ul').hide(); funkcji find('ul').

I teraz to czego nie umiem juz zrobić - jak sprawić by po kliknięciu na "Tylko dla członków" lista sie schowała ale jednocześnie pojawiły się napisy "Co nowego" oraz "O nas" - innymi słowy wrócić do punktu pierwotnego.

Pozdrawiam
Darek W.
Go to the top of the page
+Quote Post
nospor
post 29.07.2014, 10:40:48
Post #14





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




Teraz wszystko jasne smile.gif

http://jsfiddle.net/m46bb/2/


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

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
slash83
post 29.07.2014, 12:01:39
Post #15





Grupa: Zarejestrowani
Postów: 3
Pomógł: 0
Dołączył: 12.04.2004

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


Podziekował, o to mi chodziło!
Go to the top of the page
+Quote Post
Malukaz
post 29.07.2014, 12:48:19
Post #16





Grupa: Zarejestrowani
Postów: 77
Pomógł: 4
Dołączył: 16.04.2009

Ostrzeżenie: (10%)
X----


$( '#menu > li > ul' )
.hide()
.click(function( e ){
e.stopPropagation();
});
$('#menu > li').click(function(){
$('#menu > li > ul').each(function(){
$(this).slideToggle("slow");
});
});
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: 15.05.2025 - 07:44