• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Scrollspy - styl dla zawartości aktywnego odnośnika

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
0 głosów
209 wizyt
pytanie zadane 27 lipca 2017 w HTML i CSS przez SandraS Obywatel (1,400 p.)
edycja 27 lipca 2017 przez SandraS
Mam użyty scrollspy na stronie. Wszystko działa, także dla aktywnych linków nadałam style, tylko, że chciałabym zmienić kolor tła dla odpowiadającej aktywnemu  linkowi zawartości.  Używam np. $(".element_1").hasClass('active') {} ......ale to nie działa :( Jak to zrobić?

1 odpowiedź

0 głosów
odpowiedź 27 lipca 2017 przez Jedras Maniak (54,860 p.)
wybrane 27 lipca 2017 przez SandraS
 
Najlepsza

Metoda hasClass zwraca true/false, więc powinna zostać użyta w instrukcji warunkowej. Podaj więcej kodu, bo może namieszałaś.

komentarz 27 lipca 2017 przez SandraS Obywatel (1,400 p.)
    if ( $('.s1').hasClass('active') ) {
      $('#section_1').css("opacity","1");
    }
    if ( $('.s2').hasClass('active') ) {
      $('#section_2').css("opacity","1");
    }
    if ( $('.s3').hasClass('active') ) {
      $('#section_3').css("opacity","1");
    }
    if ( $('.s4').hasClass('active') ) {
      $('#section_4').css("opacity","1");
    }
    if ( $('.s5').hasClass('active') ) {
      $('#section_5').css("opacity","1");
    }
    if ( $('.s6').hasClass('active') ) {
      $('#section_6').css("opacity","1");
    }
    if ( $('.s7').hasClass('active') ) {
      $('#section_7').css("opacity","1");
    }

 

Każdy odnośnik ma klasę kolejno: s1, s2, s3....itd. i jest połączony z elementem (zawartością), i te powiązane elementy mają id, kolejno section_1, section_2...itd Chcę im nadać style :(
Zawatości mają opacity 0.5, a gdy jakiś jest aktywny chcę aby miał opacity: 1.

komentarz 27 lipca 2017 przez Jedras Maniak (54,860 p.)

I gdzie to wywołujesz ? Powinno być coś takiego:

$('#idScrollspy').on('activate.bs.scrollspy', function () {
  //sprobuj dac te ify tutaj
});

Właściwie to zamiast tych ifów możnaby użyć pętli i tylko podmienić cyferki :)

komentarz 27 lipca 2017 przez SandraS Obywatel (1,400 p.)
Działa!!!
activate.bs.scrollspy ---> co to jest?
komentarz 27 lipca 2017 przez SandraS Obywatel (1,400 p.)
Działa, ale w jedną stronę. Elementy dostają ten styl, ale idąc dalej- pozostają z tym stylem a ja bym chciała aby znikał, jak już odnośniki nie mają klasy ,,active".
komentarz 27 lipca 2017 przez SandraS Obywatel (1,400 p.)

  $('#myScrollspy').on('activate.bs.scrollspy', function () {
    if ( $('.s1').hasClass('active') ) {
      $('#section_1').css("opacity","1");
    }
    if (!$('.s1').hasClass("active")) {
    $('#section_1').css("opacity","0.5");
    }
    if ( $('.s2').hasClass('active') ) {
      $('#section_2').css("opacity","1");
    }
    if (!$('.s2').hasClass("active")) {
    $('#section_2').css("opacity","0.5");
    }
    if ( $('.s3').hasClass('active') ) {
      $('#section_3').css("opacity","1");
    }
    if (!$('.s3').hasClass("active")) {
    $('#section_3').css("opacity","0.5");
    }
    if ( $('.s4').hasClass('active') ) {
      $('#section_4').css("opacity","1");
    }
    if ( $('.s5').hasClass('active') ) {
      $('#section_5').css("opacity","1");
    }
    if ( $('.s6').hasClass('active') ) {
      $('#section_6').css("opacity","1");
    }
    if ( $('.s7').hasClass('active') ) {
      $('#section_7').css("opacity","1");
    }

  });

 

Dałam radę, dziękuję :)

komentarz 27 lipca 2017 przez Jedras Maniak (54,860 p.)

activate.bs.scrollspy to nazwa eventu (zdarzenia), który odpala się, gdy, któryś z elementów będzie aktywowany przez Scrollspy.

Najlepiej jednak zaglądnąć do źródła (dokumentacja):

https://v4-alpha.getbootstrap.com/components/scrollspy/#events

Podobne pytania

0 głosów
3 odpowiedzi 1,643 wizyt
pytanie zadane 10 stycznia 2017 w HTML i CSS przez redstar1 Bywalec (2,200 p.)
0 głosów
2 odpowiedzi 488 wizyt
pytanie zadane 5 lutego 2016 w HTML i CSS przez qoster Początkujący (350 p.)
0 głosów
2 odpowiedzi 307 wizyt
pytanie zadane 26 września 2016 w JavaScript przez Frozenfroggie Użytkownik (990 p.)

93,190 zapytań

142,205 odpowiedzi

322,032 komentarzy

62,518 pasjonatów

Advent of Code 2024

Top 15 użytkowników

  1. 2817p. - dia-Chann
  2. 2769p. - Łukasz Piwowar
  3. 2759p. - Łukasz Eckert
  4. 2738p. - CC PL
  5. 2704p. - Tomasz Bielak
  6. 2678p. - Łukasz Siedlecki
  7. 2666p. - rucin93
  8. 2485p. - Marcin Putra
  9. 2418p. - Michal Drewniak
  10. 2367p. - Adrian Wieprzkowicz
  11. 2317p. - Mikbac
  12. 2239p. - Michał Telesz
  13. 2156p. - Anonim 3619784
  14. 1733p. - rafalszastok
  15. 1628p. - Dominik Łempicki (kapitan)
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...