ไดเรกทีฟ @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;
}
}