@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;
}
}