LESS-də siniflərin genişləndirilməsi
Miksinslərin çatışmazlığı ondan ibarətdir ki, kodun təkrarı yaranır. Gəlin misal üzərində baxaq, nəyi nəzərdə tuturuq.
Tutaq ki, bizim aşağıdakı kod mövcuddur:
.mix {
width: 100px;
height: 100px;
}
p {
.mix;
color: red;
}
Bu kod aşağıdakı kimi kompilyasiya olunacaq, kod təkrarı yaradaraq:
.mix {
width: 100px;
height: 100px;
}
p {
width: 100px;
height: 100px;
color: red;
}
Daha kompakt olardı, əgər bu kod aşağıdakı kimi kompilyasiya olunsaydı:
.mix, p {
width: 100px;
height: 100px;
}
p {
color: red;
}
Buna &:extend əmrindən istifadə etməklə nail olmaq olar,
hansı ki, miksini birbaşa koda
daxil etmir, əksinə verilmiş sinifi genişləndirir. Gəlin
kodumuzu düzəldək:
.mix {
width: 100px;
height: 100px;
}
p {
&:extend(.mix);
color: red;
}
Aşağıdakı kodun kompilyasiya nəticəsinin necə olacağını izah edin:
.mix {
color: red;
font-size: 20px;
}
p {
&:extend(.mix);
width: 300px;
}
Aşağıdakı kodun kompilyasiya nəticəsinin necə olacağını izah edin:
.mix {
color: red;
font-size: 20px;
}
#block p {
&:extend(.mix);
width: 300px;
}
Aşağıdakı kodun kompilyasiya nəticəsinin necə olacağını izah edin:
.mix {
color: red;
font-size: 20px;
}
#block p, #block div {
&:extend(.mix);
width: 300px;
}
Aşağıdakı kodun kompilyasiya nəticəsinin necə olacağını izah edin:
.mix {
color: red;
font-size: 20px;
}
#block {
width: 300px;
p {
height: 100px;
&:extend(.mix);
}
div {
height: 200px;
&:extend(.mix);
}
}
Aşağıdakı kodun kompilyasiya nəticəsinin necə olacağını izah edin:
.mix1 {
color: red;
}
.mix2 {
font-size: 20px;
}
div {
width: 300px;
&:extend(.mix1);
&:extend(.mix2);
}