Ответ 1
Да, вы уже делаете это правильно. Вы можете вызвать первый mixin во втором. проверьте это перо http://codepen.io/crazyrohila/pen/mvqHo
Кто-то знает, как я могу использовать вложенные миксины или функции в SASS? У меня есть что-то вроде этого:
@mixin A(){
do something....
}
@mixin B($argu){
@include A();
}
Да, вы уже делаете это правильно. Вы можете вызвать первый mixin во втором. проверьте это перо http://codepen.io/crazyrohila/pen/mvqHo
Вы можете многомиллиметровыми мишенями, вы также можете использовать держатели мест внутри mixins.
@mixin a {
color: red;
}
@mixin b {
@include a();
padding: white;
font-size: 10px;
}
@mixin c{
@include b;
padding:5;
}
div {
@include c();
}
который выдает CSS
div {
color: red;
padding: white;
font-size: 10px;
padding: 5;
}
Как упоминалось в других ответах, вы можете включить mixins в другие mixins. Кроме того, вы можете объединить свои микшины.
Пример
.menu {
user-select: none;
.theme-dark & {
color: #fff;
background-color: #333;
// Scoped mixin
// Can only be seen in current block and descendants,
// i.e., referencing it from outside current block
// will result in an error.
@mixin __item() {
height: 48px;
}
&__item {
@include __item();
&_type_inverted {
@include __item();
color: #333;
background-color: #fff;
}
}
}
}
Будет выводиться:
.menu {
user-select: none;
}
.theme-dark .menu {
color: #fff;
background-color: #333;
}
.theme-dark .menu__item {
height: 48px;
}
.theme-dark .menu__item_type_inverted {
height: 48px;
color: #333;
background-color: #fff;
}
Scoping mixins означает, что вы можете использовать несколько микшинов одинаково в разных областях без возникновения конфликтов.