Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> jak zrobić akcię na onClik'u, w js, jquery, aby ukrywał jednego div'a a pokazywał drugiego div'a?
marcus755
post 13.12.2012, 12:11:16
Post #1





Grupa: Zarejestrowani
Postów: 158
Pomógł: 1
Dołączył: 6.12.2012

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


jak zrobić akcię na onClik'u, w js, jquery, aby ukrywał jednego div'a a pokazywał drugiego div'a?

Mam:

Ten div jest widoczny na początku.
<div id="title1">tu zawartość diva 1 </div>


<div id="title2" style="display: none;">tu zawartość diva 2 </div>


<a href="#" onClick="">Ukryj diva 1, a pokaż div 2</a>
Go to the top of the page
+Quote Post
!*!
post 13.12.2012, 12:14:45
Post #2





Grupa: Zarejestrowani
Postów: 4 298
Pomógł: 447
Dołączył: 16.11.2006

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


http://api.jquery.com/toggle/

Przy prezentowaniu kodu, używaj odpowiednich znaczników.


--------------------
Nie udzielam pomocy poprzez PW i nie mam GG.
Niektóre języki programowania, na przykład C# są znane z niezwykłej przenośności (kompatybilność ze wszystkimi wersjami Visty jest wiele warta).
Go to the top of the page
+Quote Post
johnny_b
post 14.12.2012, 18:32:20
Post #3





Grupa: Zarejestrowani
Postów: 30
Pomógł: 5
Dołączył: 3.12.2012

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


Cześć,
pozwolę sobie skomentować post - opisać moje refleksje i propozycje smile.gif. Jest to mój drugi post, więc proszę o wyrozumiałość.

Nawiązując do pytania Marcus755 js/jquery jezeli chodziło o dwa różne rozwiązania to jquery rzeczywiście jest bardzo dobrą biblioteką, ale można też napisać własną prostą funkcję z jednym warunkiem. Rzeczywiście, jak w swoim kodzie napisałeś, operuje się na wartości cechy css - display.

Dla pliku CSS:
  1. #pierwszy{display:block;} <!--deklaracje wartości dla cechy display-->
  2. #drugi{display:none;}


Dla pliku HTML:
  1. <div id="pierwszy">a</div>
  2. <div id="drugi">b</div>
  3. <input type="button" value="podmien" onClick="sprawdzKtoryAktualnieJestWidocznyIpodmien();"> <!-- to rozwiązanie nie jest najlepsze, jeżeli chodzi o rozdzielenie html od js, lepiej zastosować EventListenera w kodzie JS-->



Dla pliku JS:
  1. function sprawdzKtoryAktualnieJestWidocznyIpodmien(){
  2.  
  3. if(window.getComputedStyle(document.getElementById('pierwszy')).getPropertyValue('display') == "block"){
  4.  
  5. document.getElementById('pierwszy').style.display = "none";
  6. document.getElementById('drugi').style.display = "block";
  7. }else{
  8. document.getElementById('drugi').style.display = "none";
  9. document.getElementById('pierwszy').style.display = "block";
  10. }}



pure js wink.gif oczywiście kod do dużej optymalizacji, jednak umożliwia bezpośrednie zastosowanie funkcjonalności JS bez użycia dodatkowych, sporych, bibliotek. Niestety nie wiem czemu na IE 9 nie działa - jeżeli wiecie czemu proszę o informacje. Pozdrawiam całą społeczność smile.gif

Ten post edytował johnny_b 14.12.2012, 18:34:08
Go to the top of the page
+Quote Post
gr56
post 14.12.2012, 19:42:02
Post #4





Grupa: Zarejestrowani
Postów: 77
Pomógł: 15
Dołączył: 19.11.2011

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


getComputedStyle nie działa w IE i dlatego właśnie korzystamy z tych "sporych" bibliotek.
Go to the top of the page
+Quote Post
johnny_b
post 14.12.2012, 20:08:17
Post #5





Grupa: Zarejestrowani
Postów: 30
Pomógł: 5
Dołączył: 3.12.2012

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


Cytat(gr56 @ 14.12.2012, 19:42:02 ) *
getComputedStyle nie działa w IE i dlatego właśnie korzystamy z tych "sporych" bibliotek.


Dokładnie, tak. Zgadzam się również wiem i widzę, że nie działa smile.gif - ale jquery jakoś sobie z tym radzi, dlatego bardziej chodziło mi o opis metody w jaki sposób jquery "obsługuje" getComputedStyle w IE. Pozdrawiam
Go to the top of the page
+Quote Post
!*!
post 15.12.2012, 20:18:21
Post #6





Grupa: Zarejestrowani
Postów: 4 298
Pomógł: 447
Dołączył: 16.11.2006

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


Cytat(gr56 @ 14.12.2012, 19:42:02 ) *
getComputedStyle nie działa w IE i dlatego właśnie korzystamy z tych "sporych" bibliotek.


Działa od IE<9 wink.gif

Pod wcześniejszymi można to imitować np. http://snipplr.com/view/13523/


--------------------
Nie udzielam pomocy poprzez PW i nie mam GG.
Niektóre języki programowania, na przykład C# są znane z niezwykłej przenośności (kompatybilność ze wszystkimi wersjami Visty jest wiele warta).
Go to the top of the page
+Quote Post
johnny_b
post 15.12.2012, 21:03:16
Post #7





Grupa: Zarejestrowani
Postów: 30
Pomógł: 5
Dołączył: 3.12.2012

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


Dzięki za komentarz, również przeglądałem podesłany wątek, ale nie testowałem na w/w przykładzie, więc ciężko mi się było odnieść do kodu. Ale grunt, że można problem rozwiązać "czystym" js. Pozdrawiam
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: 14.08.2025 - 15:44