Skip to content

Sass helper to write sass code with big amount of breakpoints fast

License

Notifications You must be signed in to change notification settings

labuut/short-bp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 

Repository files navigation

short-bp

Sass helper to write sass code with big amount of breakpoints fast


recommendations on the use

В short-bp появились новые миксины, которые помогут легко и просто описывать даже большие селекторы для многих разрешений в плоском стиле, основанном на объектах (мапах):

mobile-props(mobile-props($args-map);
desktop-props(mobile-props($args-map);
all-props(mobile-props($args-map);

Все они внутри просто вызывают миксину restricted-props с различными параметрами, но это не так важно.

##Общий принцип описания селекторов:

.className {
    @include mobile-props((
        // статичные свойства
        font-size: 12px,
        color: red,
        
        // изменяющиеся свойства
        width: (
            360: 16px,
            400: 14px,
        ),
        height: (
            0: 14px,
            360: 16px,
        ),
    ));
    @include desktop-props((
        font-size: 22px,  
        width: (
            1024: 16px,
            1366: 14px,
        ),
        height: (
            1366: 14px,
            2048: 16px,
        ),
    ));
}

##Основные пункты: не определять стили просто внутри селектора, а обязательно задавать их область действия через миксины mobile/desktop/all-props;

использовать all-props в редких случаях: на страницах лендингов, для срочной верстки и для описания стилей, явно относящихся ко всем разрешениям (например для задания параметров анимаций);

Пример:

.className {
    @include mobile-props((
        font-size: 12px,
        width: (
            360: 16px,
            400: 14px,
        ),
    ));
    @include desktop-props((
        font-size: 22px,  
        width: (
            1024: 16px,
            1366: 14px,
        ),
    ));
    @include all-props((
        transition: width 500ms;
    ));
}

##Границы действия: При использовании этих миксин можно больше не бояться, что мобильные стили при изменении изменят десткопные или наоборот, т.к. при определении стилей таким образом они действуют только на те разрешения (mobile/desktop/all-props), для которых заданы (главное, правильно определить max/min-ширины для мобильных/десктопных разрешений в файле cool-media-queries.scss):

.className {
    @include mobile-props(( // действует только на мобильные разрешения
        width: (
            360: 16px,
            1440: 14px, // работать не будет
        ),
    ));
}

##Вложенные селекторы: В миксинах mobile/desktop/all-props нельзя определять вложенные селекторы/псевдоэлементы/псевдоклассы. В этом случае их нужно выносить на уровень основного селектора и также использовать mobile/desktop/all-props внутри вложенного элемента:

.className {
    @include mobile-props((
        width: (
            360: 16px,
            400: 14px,
        ),
    ));
  
    // вложенный селектор
    &:last-child {
        @include mobile-props((
            width: (
                360: 26px,
                400: 24px,
            ),
        ));
    }
}

About

Sass helper to write sass code with big amount of breakpoints fast

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages