169 похожих чатов

Вот на практике я столкнулся с несколькими вопросами по БЭМ

и, хотя, я пересмотрел, наверное, все БЭМ-митапы и многие другие видео по БЭМУ, для меня ответы на, казалось, такие очевидные вопросы остались не совсем очевидными.

Допустим, у меня есть такая структура:

...
<body>

<header class="header">
<span class="header__logo">LOGO</span>
</header>

<h1>Its home page</h1>

<div class="some-block">
<p class="some-block__text">Some stuff</p>
</div>

<div class="some-block">
<p class="some-block__text">Some another stuff</p>
</div>

</body>
</html>

И CSS:

.header {
background-color: orangered;
}

.some-block {
background-color: orange;
}

.some-block__text {
margin: 0;
}

Первый вопрос. Что если мне нужно для блока *Header* поставить margin-bottom: 10px? Так как это блок и я хочу его переиспользовать, то для него задать я не могу. В таких случаях идеально должны подойти миксы, те сделать *Header* элементом другого блока, НО какого?

...
.???__header {
margin-bottom: 10px;
}

Второй вопрос. Вот у меня на этой странице есть 2 блока *Some Block* и для них мне нужно сделать margin: 15px, те мне опять же нужно сделать его элементом какого-то блока (какого и как я пойму из первого ответа) и опять же сделать:

...
.???__some-block (или?) {
margin: 10px;
}

Но что если для второго такого-же блока мне нужно, чтобы правый внешний отступ был 20px: margin-right: 20px (и это исключительно особенность его расположения на этой страницы, как и внешние отступы по 10px, просто для второго такого-же блока правый отступ нужен в 20px).

Третий вопрос. Что если у меня появились еще 3 дополнительных страницы, например, *About*, *Contacts* и *Policy* на каждой из которых (КРОМЕ *Contacts*) у блока *Header* как и на странице *Home* margin-bottom: 10px, а на странице *Contacts* margin-bottom: 15px (это чисто дизайнерская особенность этой странице и этот отступ для блока *Header* в 15px зависит только от того, что он находится на странице *Contacts*).

Четвертый вопрос. На каждой странице, как в примере со страницей *Home* у меня есть заголовок (h1), который показывает на какой странице я нахожусь и стили которого я до этого момента оставлял базовыми, но вот теперь я решил задать, что на всех этих страницах он будет размером в 27px, те мне его нужно выделить в отдельный блок? Или же на каждой странице сделать его элементом какого-то другого абстрактного блока (какого я пойму из первого вопроса)?

И вот я выделил как-то этот заголовок, но что если на странице *Home* (что является особенностью этой страницы) этот заголовок имеет размер 30px и color: green? Что сделать в этом случае?

2 ответов

6 просмотров

1) сделай <body class="page"> и тогда хедеру можно сделать миксин или обёртку от этого page блока. 2) если я правильно понял то ответ как и в первом вопросе. Ты можешь например навесить миксинов с говорящими именами page__someblock page__someblock_mr10 в стиле emmet, мне кажется это оправдано если существуют такие потребности. Или лучше вообше тут не использовать миксины, а модификатор делать к этому сомеблоку someblock_mb10 3) тоже. Меняешь на этих страницах модификаторы для элемента page__header в тех местах, где это нужно. 4) желательно любому элементу задавать бэм классы. Какието состояния элемента отличные от базовых нужно выделять при помощи модификаторов Если что-то не понятно -- спрашивай, могу на коде показать например

veal- Автор вопроса
Андрей Гуртовой
1) сделай <body class="page"> и тогда хедеру можно...

да спасибо я уже нашел ответы на все вопросы)

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

Обсуждают сегодня

читать файл максимально быстро? странный вопрос))
zamtmn
53
Привет. Сразу скажу, что на C/C++/Rust я не пишу, но тем не менее возникла потребность дебага C/C++/Rust кода. Суть: есть серверное приложение, которое периодически ведёт себ...
ninekeem 🐳
4
А чего сейчас в моде вместо Error для эксепшенов? А то я тут внезапно узрел что он не рекомендуется :) У Try::Tiny какой-то совершенно ужасный синтаксис если надо конкретные э...
Denis F
16
или вы считаете муит дает знание?
супер_лох_3000 альфа версия
12
А кто такой мужчина в твоем понимании Азиз?
who?です 🐈
11
Ну значит тебе повезло, мы же про транк говорим оба?
Александр (Rouse_) Багель
11
всем привет! углубившись в плюсы и начав изучать реверсинг понял, что без асм'а никуда со своими высокоабстрактными представлениями начал изучать механизмы асма, и не совсем п...
9
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Всем ку. Подскажите, если задекларировал массив так: int arr[10] = {1, 2, 3, 4}, то в arr[4] будет мусор или нуль?
Sasha K
14
буквально один оставшийся вопрос при выполнении строчки mov eax, 5 операнд "5" будет присутствовать где-либо в памяти (любой), кроме как в памяти блока .code? подвопрос: как...
12
Карта сайта