Evgenii Legotckoi
11 апреля 2017 г. 13:00

Как использовать функцию calc() в СSS для создания сетки

CSS

Всем привет!
Подскажите, как использовать функцию calc() в CSS, чтобы сделать сетку, например, как в Bootstrap? Только чтобы всё рассчитывалось от какой-нибудь переменной. Там вроде же можно задавать переменные уже?

2

Вам это нравится? Поделитесь в социальных сетях!

2
Evgenii Legotckoi
  • 11 апреля 2017 г. 23:36
  • Ответ был помечен как решение.

Добрый день!

Чтобы использовать и функцию calc() и переменную var в этой функции для организации сетки ( GRID ), нужно написать класс CSS, который будет содержать переменную, от которой будет производиться расчёт, а также написать ещё комплект стиле, которые будут перегружать эту переменную.

Например, напишем класс ячейки cell , у которого будет две переменных, которые будут отвечать за количество колонок (переменная --col ), которое будет занимать ячейка и за сдвиг с левого края (переменная --offset ). При этом всего будет в одной строке находиться до десяти ячеек. То есть минимальная ширина ячейки будет равна 10%.

.cell
{
    display: inline-block;
    --col: 10;
    --offset: 0;
    width:  -webkit-calc(10% * var(--col));
    width:     -moz-calc(10% * var(--col));
    width:          calc(10% * var(--col));
    margin-left: -webkit-calc(10% * var(--offset));
    margin-left:    -moz-calc(10% * var(--offset));
    margin-left:         calc(10% * var(--offset));
}

По умолчанию ячейка будет занимать 100% ширины строки.

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

[data-col="1"] { --col: 1; }
[data-col="2"] { --col: 2; }
[data-col="3"] { --col: 3; }
[data-col="4"] { --col: 4; }
[data-col="5"] { --col: 5; }
[data-col="6"] { --col: 6; }
[data-col="7"] { --col: 7; }
[data-col="8"] { --col: 8; }
[data-col="9"] { --col: 9; }
[data-col="10"] { --col: 10; }

Аналогично для сдвига ячейки:

[data-offset="1"] { --offset: 1; }
[data-offset="2"] { --offset: 2; }
[data-offset="3"] { --offset: 3; }
[data-offset="4"] { --offset: 4; }
[data-offset="5"] { --offset: 5; }
[data-offset="6"] { --offset: 6; }
[data-offset="7"] { --offset: 7; }
[data-offset="8"] { --offset: 8; }
[data-offset="9"] { --offset: 9; }
[data-offset="10"] { --offset: 10; }

Применение:

<div class="cell" data-col="4" data-offset="2"></div>

Получим ячейки на 4 колонки со сдвигом на 2 колонки.

    Evgenii Legotckoi
    • 12 апреля 2017 г. 0:44

    Спасибо ))

      Комментарии

      Только авторизованные пользователи могут публиковать комментарии.
      Пожалуйста, авторизуйтесь или зарегистрируйтесь
      • Последние комментарии
      • Evgenii Legotckoi
        16 апреля 2025 г. 17:08
        Благодарю за отзыв. И вам желаю всяческих успехов!
      • IscanderChe
        12 апреля 2025 г. 17:12
        Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
      • AK
        1 апреля 2025 г. 11:41
        Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
      • Evgenii Legotckoi
        9 марта 2025 г. 21:02
        К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
      • VP
        9 марта 2025 г. 16:14
        Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…