Задать вопрос
@wakenbyWork

Как лучше поступать в такие моменты по bem?

Например есть такой блок с элементами:

<div class="some-class">
  <div class="some-class__close">
    <svg class="some-class__close-icon"></svg>
  </div>

  <div class="some-class__card">
    <div class="some-class__card-picture"></div>
    <div class="some-class__card-title"></div>
    <div class="some-class__card-desc"></div>
    <div class="some-class__card-btn"></div>
  </div>
</div>


И вопрос можно ли так делать? Просто эти элементы ни где не встречаются больше кроме такого блока, и создавать новые блоки не знаю нужно ли?

На счет card, тут я понимаю что лучше создать новый блок, будет чище выглядеть, но с close, close-icon я не уверен.

Не подскажите как делать в таких ситуациях?
  • Вопрос задан
  • 264 просмотра
Подписаться 3 Простой Комментировать
Решения вопроса 1
SeaInside
@SeaInside
15 лет пилю все эти штуки
Эта разметка абсолютно правильная в двух случаях:
1) Ваши `close` и `card` действительно нигде не переиспользуются;
2) Объём стилей блока `some-class` остаётся адекватным для восприятия.

Соответственно, вам нужен новый блок в двух случаях: либо он переиспользуется, либо для разделения кода для простоты восприятия.

Возьмём разметку посложнее (не надо в ней искать какого-то смысла, просто от фонаря что-то набрал для иллюстрации):
<div class="block">
  <!-- Header -->
  <div class="block__header">
    <h2 class="block__title">Title</h2>
    <div class="block__actions">
      <button type="button" class="block__action block__action--edit">
        <span class="block__action-icon"></span>
      </button>
    </div>
  </div>
  <!-- Content -->
  <div class="block__content">
    <p>...</p>
  </div>
  <!-- Footer -->
  <div class="block__footer">
    <div class="block__about">
      <div class="block__author"></div>
      <div class="block__date"></div>
    </div>
    <div class="block__awards">
      <div class="block__award">
        <div class="block__award-inner"></div>
        <div class="block__award-tooltip">
          <div class="block__award-tooltip-content"></div>
          <button type="button" class="block__award-tooltip-close"></button>
        </div>
      </div>
    </div>
  </div>
</div>


Положим, что весь контент этого блока уникальный и никак не переиспользуется.
Объём стилей `block` при такой структуре неизбежно станет некомфортным для восприятия, строк на 200-300.

В таком случае хорошо создать внутренний блок (или несколько) просто для того, чтобы размазать сложность.
`block-header`, `block-footer` или даже `block-footer-award`.

Самое главное здесь организовать файловую структуру / конфигурационный файл / чем вы там ещё собираете таким образом, чтобы было очевидно, что `block-footer` - это не самостоятельный блок, а внутренний блок `block`, нужный только для упрощения восприятия, и он не может / не должен использоваться в отрыве от него (в этом случае у него не должно быть в названии общего префикса с `block`, чтобы не создавать путаницу)

* И не забывать о том, что даже для таких внутренних блоков действуют те же самые правила, что и для других - вся внешняя геометрия задаётся через элементы.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы