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

BEM - modyfikator bloku

Object Storage Arubacloud
0 głosów
128 wizyt
pytanie zadane 10 sierpnia 2019 w HTML i CSS przez hun1er76 Stary wyjadacz (11,960 p.)

Dzień dobry, mam pytanie odnośnie do metodyki BEM. Jak zaimplementować element, który bardzo się wyróżnia wyglądem (zawartość taka sama) na tle pozostałych elementów tego typu? Poniżej zamieszczam zdjęcie poglądowe.

Mamy wygląd elementu A) i chcemy wystylować wygląd B).

Struktura elementu A mogłaby być taka (pomijając semantykę)

<div class="entry">
    <div class="entry__date">Data</div>
    <div class="entry__title">Tytuł 1</div>
    <div class="entry__content">...</div>
</div>

Moje proponowane rozwiązania to

<div class="entry entry--dark">
    <div class="entry__date">Data</div>
    <div class="entry__title">Tytuł 2</div>
    <div class="entry__content">...</div>
</div>

albo

<div class="entry entry--dark">
    <div class="entry__date entry__date--secondary">Data</div>
    <div class="entry__title entry__title--invert">Tytuł 2</div>
    <div class="entry__content">...</div>
</div>

W pierwszym rozwiązaniu łamana jest płaska specyficzność css'a, natomiast w drugim dodane dużo nadmiarowego kodu oraz utrudniona programowa zmiana tego bloku, gdyż trzeba użyć aż trzech funkcji js.

Właściwie pytanie powinno brzmieć, czy modyfikator bloku może modyfikować właściwości elementów tego bloku? Oraz jak rozwiązalibyście powyższy problem?

1 odpowiedź

0 głosów
odpowiedź 10 sierpnia 2019 przez rafal.budzis Szeryf (85,260 p.)
wybrane 13 sierpnia 2019 przez hun1er76
 
Najlepsza
<div class="entry entry--dark">
    <div class="entry__date">Data</div>
    <div class="entry__title">Tytuł 2</div>
    <div class="entry__content">...</div>
</div>

Ten kod ^ jest poprawnym rozwiązaniem. Możesz też użyć zmiennych CSS wówczas zachowasz płaskie selektory. np:

.entry {
     --title-color: #000;
}
.entry--dark {
     --title-color: #fff;
}
.entry__title {
     color: var(--title-color);
}

https://budzis.pl/Wpisy/Kursy/Optymalizacja-stron/Metodologia-BEM/

Podobne pytania

0 głosów
2 odpowiedzi 441 wizyt
+2 głosów
1 odpowiedź 219 wizyt
pytanie zadane 30 kwietnia 2021 w HTML i CSS przez rafal.budzis Szeryf (85,260 p.)
+1 głos
1 odpowiedź 245 wizyt
pytanie zadane 19 sierpnia 2022 w HTML i CSS przez Hoorder Początkujący (470 p.)

92,568 zapytań

141,420 odpowiedzi

319,623 komentarzy

61,956 pasjonatów

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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...