@media դիրեկտիվը SASS-ում
SASS-ում @media դիրեկտիվը կիրառվում է նույն կերպ, ինչ
CSS-ի համապատասխան կանոնը: Եվ նաև այն կարելի է
անմիջապես ներդնել բոլոր CSS կանոնների մեջ:
Պետք է նշել, որ երբ մենք ներդնում ենք
@media դիրեկտիվը CSS-ի կանոնի մեջ, կոմպիլյացիայից հետո
այն բարձրանում է վեր՝ ոճերի աղյուսակների վրա, իսկ այն սելեկտորները,
որոնցում տեղադրված էր դիրեկտիվը, տեղափոխվում են @media-ի ներսում:
Դրանից ելնելով, կարելի է ավելացնել կանոններ @media դիրեկտիվում
առանց սելեկտորները կրկնելու կամ ոճերի աղյուսակի հոսքը խախտելու:
Դիտարկենք օրինակ.
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Այժմ նայենք կոմպիլյացիայի արդյունքին.
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Կա նաև @media հարցումները մեկը մյուսի մեջ ներդնելու հնարավորություն,
իսկ կոմպիլյացիայից հետո
դրանք միացվում են and օպերատորով.
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Ահա թե ինչ ենք տեսնում կոմպիլյացիայից հետո.
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
@media դիրեկտիվի ևս մեկ առանձնահատկություն
այն է, որ դրա միջոցով կարելի է փոխանցել
փոփոխականներ, ֆունկցիաներ և օպերատորներ.
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
Իսկ style.css ֆայլում մենք ստանում ենք հետևյալ կոդը.
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Պատմեք, թե ինչ կլինի հետևյալ կոդի կոմպիլյացիայի արդյունքը.
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Պատմեք, թե ինչ կլինի հետևյալ կոդի կոմպիլյացիայի արդյունքը.
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Պատմեք, թե ինչ կլինի հետևյալ կոդի կոմպիլյացիայի արդյունքը.
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}