С Новым годом! Форум программистов, компьютерный форум, киберфорум
HTML, CSS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 10.09.2017
Сообщений: 18

"Умный" отступ в блоке CSS

04.10.2019, 10:23. Показов 1155. Ответов 9

Студворк — интернет-сервис помощи студентам
Всем привет, проблема следующая, есть 4 блока, в каждом иконка/картинка, заголовок и текст. Заголовок в одном блоке может вмещаться в одну строку, в другом из-за длинны занимать 2 строчки, но текст от заголовка в каждом блоке должен быть на одном и том же расстоянии. Сами блоки сверстаю путем flex box, а вот "умный" отступ не знаю, как сделать. Position absolute для текста не предлагать, т.к. если я захочу добавить в содержимое еще 100 слов(например), то текст останется внизу бе увеличения высоты общего блока и наедет на на заголовок и иконку/картинку. Через table тоже нежелательно. Пример выложу.
Миниатюры
"Умный" отступ в блоке CSS  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.10.2019, 10:23
Ответы с готовыми решениями:

CSS - текст в блоке - отступ сверху (всегда на 1px > других браузеров)
Ситуация: текст в блоке всегда имеет на 1px больше отступ сверху чем в других браузерах. Для примера, есть один тег в который добавлен...

Убрать отступ сверху во вложенном блоке
Добрый день! у меня стоит блок <div id="block-body"> в него вложен еще один блок <div id="block-header"> он подключается с...

Отступ в css
Добрый день! создал такой встроенный класс: .str27A4:before { content: '\27A4\2003'; margin-left: 2%; } Как сделать так,...

9
469 / 334 / 144
Регистрация: 16.02.2018
Сообщений: 930
04.10.2019, 11:30
Без ограничения высоты для блока текста так не сделать.
1. Либо ограничивайте высоту блока руками в котором текст, и все что не влазит вы обрежете, или же через js вычисляйте высоту максимально большого блока, и задавайте её всем.
1
1786 / 1036 / 445
Регистрация: 12.05.2016
Сообщений: 2,550
04.10.2019, 11:43
Цитата Сообщение от novichek_1905 Посмотреть сообщение
Либо ограничивайте высоту блока руками в котором текст, и все что не влазит вы обрежете
novichek_1905, еще можно min-height задать заголовку, но это тоже такой себе вариант...
1
469 / 334 / 144
Регистрация: 16.02.2018
Сообщений: 930
04.10.2019, 13:09
Цитата Сообщение от shvyrevvg Посмотреть сообщение
но это тоже такой себе вариант...
ага, но проблему ТС не решает, тут вон что:
Цитата Сообщение от Huga55 Посмотреть сообщение
если я захочу добавить в содержимое еще 100 слов(например)
0
0 / 0 / 0
Регистрация: 10.09.2017
Сообщений: 18
04.10.2019, 21:20  [ТС]
И так господа, спасибо за помощь, помучился я немного... но решение нашел) при помощи псевдоэлемента и flexbox, можно и любым другим элементом воспользоваться, но т.к. по дизайну не предусмотрен, то решил использовать before, отступ будем задавать от него, т.к. он не переносится на др строку и тд и вообще имеет высоту и ширину 0px) ближе к делу:

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<div class="why__bottom">
                                    <div class="why__bottom-box">
                                        <img src="img/why1.png" alt="" class="why__box-img">
                                        <div class="why__box-title">Свой инженерный центр</div>
                                        <div class="why__box-text">Наши инженеры абсолютно бесплатно сделают Вам грамотный, качественный просчет исходя из особенностей вашего помещения</div>
                                    </div>
                                    <div class="why__bottom-box">
                                        <img src="img/why2.png" alt="" class="why__box-img">
                                        <div class="why__box-title">Гарантия</div>
                                        <div class="why__box-text">На всю нашу продукцию идет официальная гарантия от производителя. 10 лет на корпус в металле с порошковым покрытием из высококачественной стали 10 лет на медно-алюминиевый теплообменник</div>
                                    </div>
                                    <div class="why__bottom-box">
                                        <img src="img/why3.png" alt="" class="why__box-img">
                                        <div class="why__box-title">Бесплатная доставка</div>
                                        <div class="why__box-text">Еще одной особенностью нашей компании является полностью БЕСПЛАТНАЯ доставка на територии всей Украины</div>
                                    </div>
                                    <div class="why__bottom-box">
                                        <img src="img/why4.png" alt="" class="why__box-img">
                                        <div class="why__box-title">Европейское качество материалов</div>
                                        <div class="why__box-text">На производстве используются исключительно европейские комплектующие</div>
                                    </div>
                                </div>


CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
.why__bottom{
    padding-top: 40px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
}
 
 
 
.why__bottom-box{
    max-width: 268px;
}
 
 
.why__box-img{
    margin:0 auto 30px auto;
    display: block;
}
 
.why__box-title{
    font-size: 18px;
    text-align: center;
    display: flex;
    align-items: flex-start;
    justify-content: center;
}
 
.why__box-title:before{
    content: "";
    display: block;
    margin-bottom: 50px;
}
 
 
.why__box-text{
    font-size: 14px;
    font-family: "UbuntuItalic", sans-serif;
    word-wrap: break-word;
}
результат прикреплю в картинке. Может кому пригодиться этот способ(мне например).
Миниатюры
"Умный" отступ в блоке CSS  
0
469 / 334 / 144
Регистрация: 16.02.2018
Сообщений: 930
04.10.2019, 23:49
Huga55, вы меня конечно простите, но как ваш пример удовлетворяет вашему же условию?)
Цитата Сообщение от Huga55 Посмотреть сообщение
Position absolute для текста не предлагать, т.к. если я захочу добавить в содержимое еще 100 слов(например)
У вас не просто не получиться добавить сколько вы хотите текста, но и это будет выглядеть ужасно)

И почему не задать min-height, как говорилось выше?) В Общем и целом, то ли вы не сформулировали до конца условия, то ли нашли для себя компромисс, но решением задачи исходя из вашего первичного описания, назвать это я бы не смог)
0
0 / 0 / 0
Регистрация: 10.09.2017
Сообщений: 18
05.10.2019, 10:47  [ТС]
Вопрос к вам, вы проверяли? или доверились интуиции??) просто я проверил и моим требованиям удовлетворило. На самом деле это не мое требование, это логично, что подобный сайт верстается для заказчика и со временем, есть вероятность, что он захочет изменить там текст. Пруфы прилагаю(в последний блок добавил ровно 100 слов).
Миниатюры
"Умный" отступ в блоке CSS  
0
469 / 334 / 144
Регистрация: 16.02.2018
Сообщений: 930
05.10.2019, 10:53
Цитата Сообщение от Huga55 Посмотреть сообщение
Вопрос к вам, вы проверяли? или доверились интуиции??)
вы тогда точнее излагайте, какой именно текст имеется ввиду. Я думал вы о тексте в заголовке, потому как вся задумка ради него) Просто подобные вещи решаются с помощью min-height
2
1786 / 1036 / 445
Регистрация: 12.05.2016
Сообщений: 2,550
05.10.2019, 12:13
Huga55, зачем делать через заднее место, если можно .why__box-title задать min-height 50px?
1
0 / 0 / 0
Регистрация: 10.09.2017
Сообщений: 18
05.10.2019, 13:09  [ТС]
Цитата Сообщение от novichek_1905 Посмотреть сообщение
вы тогда точнее излагайте, какой именно текст имеется ввиду. Я думал вы о тексте в заголовке, потому как вся задумка ради него) Просто подобные вещи решаются с помощью min-height
хм, действительно, у меня была такая мысль, но меня оттолкнула она тем, что при уменьшении ширины экрана один из заголовков станет слишком высоким(из-за переноса слов) и отступ станет разным, я понимаю, что ошибался, забыл, что верстка адаптивная и такого не случится... В общем спасибо. А по поводу заголовка, ну
наедет на на заголовок и иконку/картинку.
предполагалось, что наедет сначала на заголовок, потом на картинку, следовательно речь шла конкретно об описании в каждом блоке, но согласен, что не однозначно) в любом случае проблема решена, всем спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.10.2019, 13:09
Помогаю со студенческими работами здесь

Отступ в CSS
Имеется ксс код: body{ background-image: url(&quot;logo.jpg&quot;); background-repeat: no-repeat; background-attachment: fixed; ...

Отступ | CSS
Здравствуйте. Имеем слудующий код: &lt;header&gt; &lt;a href=&quot;http://neat-shop.com&quot;&gt;&lt;h1&gt;MYSITE.COM&lt;/h1&gt;&lt;/a&gt; &lt;div class=&quot;menu&quot;&gt;...

CSS. Отступ от кнопки вверх
Добрый день, на сайте https://www.ledx.no/produkt/led-gards-gatebelysning-80-watt-led/ я хочу сделать отступ вверх от кнопки...

Как убрать отступ? (CSS)
Как убрать этот отступ в выпадающем меню?

Не понятный отступ сверху сайта [CSS]
Здравствуйте, на сайте появился магический отступ сверху сайта. Если смотреть через Оперу,то его не видно, а вот если смотреть черех Хром ,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru