گردآوری تمام روش هایی که ویژگی های رسانه به شما امکان می دهد به دستگاه ها و اولویت ها پاسخ دهید.
طراحی پاسخگو بدون پرسش های رسانه ای امکان پذیر نخواهد بود. قبل از پرسش های رسانه ای، هیچ راهی برای دانستن اینکه افراد از چه نوع دستگاهی برای بازدید از وب سایت شما استفاده می کنند، وجود نداشت. طراحان باید فرضیاتی میکردند. این مفروضات در طرحهای با عرض ثابت یا طرحبندی مایع کدگذاری شدند.
همه اینها با معرفی پرسش های رسانه ای تغییر کرد. برای اولین بار طراحان توانستند در نیمه راه با مردم ملاقات کنند. طراحان میتوانند طرحبندی خود را طوری تنظیم کنند که به دستگاههای افراد پاسخ دهد.
به یاد داشته باشید، درخواست رسانه شامل یک نوع رسانه اختیاری و یک ویژگی رسانه اجباری است. در طول این سال ها تغییر چندانی در انواع رسانه ها ایجاد نشده است. هنوز فقط چهار مقدار ممکن وجود دارد:
@media all
@media screen
@media print
@media speech
از سوی دیگر، ویژگیهای رسانه بسیار گسترش یافته است. اکنون طراحان میتوانند با کاربران فراتر از نیمه راه ملاقات کنند و طرحها را طوری تطبیق دهند که بسیار بیشتر از اندازه صفحه نمایش باشد.
ابعاد ویوپورت
محبوبترین پرسشهای رسانهای در وب، مواردی هستند که با عرض درگاه نمایش سروکار دارند. اما حتی در اینجا، شما با یک انتخاب روبرو هستید. میتوانید از ویژگی max-width
رسانه برای اعمال سبکهای زیر یک عرض معین استفاده کنید، یا میتوانید از ویژگی رسانه min-width
برای اعمال سبکهای بالاتر از عرض معین استفاده کنید.
main {
display: grid;
grid-template-columns: 2fr 1fr;
}
@media (max-width: 45em) {
main {
display: block;
}
}
@media (min-width: 45em) {
main {
display: grid;
grid-template-columns: 2fr 1fr;
}
}
من شخصاً دوست دارم از min-width
استفاده کنم. من سبک های چیدمان را به روشی افزودنی اعمال می کنم. من قوانین طرح بندی جدیدی را در هر نقطه شکست به جای لغو قوانین قبلی معرفی می کنم.
این رویکرد افزودنی برای ارتفاع نیز کار می کند. با استفاده از min-height
میتوانید قوانین بیشتری را با در دسترس قرار گرفتن ارتفاع بیشتر درگاه معرفی کنید. برای مثال، ممکن است یک عنصر هدر داشته باشید که اگر فضای عمودی کافی وجود دارد، بخواهید آن را به بالای پنجره مرورگر متصل کنید.
@media (min-height: 30em) {
header {
position: fixed;
}
}
اما در صورت تمایل می توانید از ویژگی رسانه max-height
استفاده کنید. در اینجا، هدر به طور پیشفرض لنگر است، اما اگر فضای عمودی کافی وجود نداشته باشد، چسبندگی حذف میشود.
header {
position: fixed;
}
@media (max-height: 30em) {
header {
position: static;
}
}
انتخاب بین پیشوندهای min-
و max-
فقط برای width
و height
اعمال نمی شود. ویژگی رسانه aspect-ratio
همین انتخاب را ارائه می دهد. همچنین اگر می خواهید استایل ها را با نسبت دقیق عرض به ارتفاع اعمال کنید، یک نسخه بدون پیشوند ارائه می دهد.
@media (min-aspect-ratio: 16/9) {
// The ratio of width to height is at least 16 by 9.
}
@media (max-aspect-ratio: 16/9) {
// The ratio of width to height is less than 16 by 9.
}
@media (aspect-ratio: 16/9) {
// The ratio of width to height is exactly 16 by 9.
}
ارائه سبک های مختلف برای نسبت های مختلف می تواند به سرعت از کنترل خارج شود. اگر به آن سطح دقیق از کنترل نیاز ندارید، ویژگی رسانه orientation
ممکن است با نیازهای شما مطابقت بیشتری داشته باشد. دو مقدار ممکن دارد: portrait
یا landscape
.
@media (orientation: portrait) {
// The width is less than the height.
}
@media (orientation: landscape) {
// The width is greater than the height.
}
حتی اگر عبارات "عمودی" و "منظره" اغلب برای اشاره به جهت گیری دستگاه های تلفن همراه استفاده می شود، ویژگی رسانه orientation
مختص دستگاه نیست. یک پنجره مرورگر تمام صفحه در یک لپتاپ معمولی دارای مقدار orientation
landscape
است.
نمایش می دهد
نمایشگرهای مختلف دارای تراکم پیکسلی متفاوتی هستند که بر حسب dpi
، نقطه در اینچ اندازه گیری می شود. میتوانید با استفاده از ویژگی رسانه resolution
، استایلهای خود را برای تراکم پیکسلهای مختلف تنظیم کنید. مانند aspect-ratio
، resolution
در سه نوع ارائه می شود: حداقل، حداکثر و دقیق.
@media (min-resolution: 300dpi) {
// The display has a pixel density of at least 300 dots per inch.
}
@media (max-resolution: 300dpi) {
// The display has a pixel density less than 300 dots per inch.
}
@media (resolution: 300dpi) {
// The display has a pixel density of exactly 300 dots per inch.
}
ممکن است هرگز نیازی به استفاده از پرس و جوهای رسانه ای resolution
نداشته باشید. تراکم پیکسل معمولاً فقط برای تصاویر یک مشکل است و تصاویر واکنش گرا راهی برای مقابله مستقیم با تراکم پیکسل در HTML هستند.
از طرف دیگر، CSS جایی است که شما انیمیشن ها و انتقال های خود را تعریف می کنید. میتوانید با استفاده از ویژگی update
رسانه، آن انیمیشنها و انتقالها را طوری تنظیم کنید که به نرخهای تازهسازی متفاوت پاسخ دهند. این ویژگی رسانه یکی از سه مقدار را گزارش میکند: none
، slow
، و fast
.
مقدار update
none
به این معنی است که نرخ تازهسازی وجود ندارد. برای مثال، یک صفحه چاپ شده را نمی توان به روز کرد.
مقدار update
slow
به این معنی است که نمایشگر نمیتواند به سرعت تازهسازی شود. نمایشگر جوهر الکترونیکی نمونه ای از صفحه نمایش با نرخ تازه سازی کند است.
مقدار update
fast
به این معنی است که نمایشگر آنقدر سریع تازه میشود که بتواند انیمیشنها و انتقالها را مدیریت کند.
@media (update: fast) {
a {
transition-duration: 0.4s;
transition-property: transform;
}
a:hover {
transform: scale(150%);
}
}
همه جنبه های نمایشگر به قابلیت های سخت افزاری مربوط نمی شود. در ماژول theming ، نحوه تعریف ویژگی ها در فایل مانیفست برنامه وب را مشاهده کردید. یکی از این ویژگی ها display
نام دارد و می توانید به آن مقدار fullscreen
، standalone
، minimum-ui
یا browser
بدهید. ویژگی مدیا display-mode
مربوطه به شما امکان می دهد سبک های خود را برای این گزینه های مختلف تنظیم کنید.
فرض کنید یک مقدار display
standalone
در مانیفست برنامه وب خود ارائه کرده اید. اگر شخصی سایت شما را به صفحه اصلی خود اضافه کند، سایت بدون رابط مرورگر راه اندازی می شود. ممکن است تصمیم بگیرید که یک دکمه برگشت را برای آن کاربران نمایش دهید.
button.back {
display: none;
}
@media (display-mode: standalone) {
button.back {
display: inline;
}
}
رنگ
ویژگی های رسانه ای متعددی برای پرس و جو از قابلیت های رنگ یک دستگاه وجود دارد. اگر میخواهید استایلهای خود را برای هر نمایشگری که فقط سایههای خاکستری را تولید میکند تنظیم کنید، میتوانید از ویژگی رسانه monochrome
بدون هیچ ارزشی استفاده کنید.
@media (monochrome) {
body {
color: black;
background-color: white;
}
}
یک ویژگی رسانه color
مربوطه وجود دارد.
@media (color) {
body {
color: maroon;
background-color: linen;
}
}
برای صفحههای رنگی، میتوانید پرسوجوهایی را با ویژگیهای رسانه color-gamut
، color-index
یا dynamic-range
بنویسید. همه آنها جزئیات خاصی را در مورد قابلیت های رنگی صفحه نمایش گزارش می دهند.
در این مثال، مقادیر رنگ در پاسخ به ویژگی رسانه dynamic-range
، که ترکیبی از حداکثر روشنایی، عمق رنگ و نسبت کنتراست نمایشگر را گزارش میکند، بهروزرسانی میشوند. مقادیر ممکن standard
یا high
هستند. به صفحهای با وضوح بالا که یک مقدار dynamic-range
high
را گزارش میکند، با استفاده از تابع color()
CSS جدید، فضای رنگی متفاوتی داده میشود.
.neon-red {
color: hsl(355 100% 95%);
}
@media (dynamic-range: high) {
.neon-red {
color: color(display-p3 1 0 0);
}
}
تعامل
ویژگیهای رسانه همچنین میتوانند نوع مکانیزم ورودی مورد استفاده برای تعامل با سایت شما را گزارش کنند: hover
، any-hover
، pointer
و any-pointer
. برای جزئیات بیشتر به ماژول تعامل مراجعه کنید.
ترجیحات
طیف وسیعی از پرسشهای رسانه وجود دارد که به شما امکان میدهد به تنظیمات برگزیده کاربر پاسخ دهید: prefers-color-scheme
، prefers-contrast
و prefers-reduced-motion
. برای جزئیات بیشتر، ماژولهای موضوعبندی و دسترسی را ببینید.
میتوانید ویژگیهای رسانه را در یک درخواست رسانه ترکیب کنید. میتوانید سبکهای انیمیشن خود را طوری تنظیم کنید که فقط در صورتی اعمال شوند که دستگاه دارای نرخ تازهسازی سریع باشد و کاربر تمایلی به کاهش حرکت نشان نداده باشد.
@media (update: fast) and (prefers-reduced-motion: no-preference) {
a {
transition-duration: 0.4s;
transition-property: transform;
}
a:hover {
transform: scale(150%);
}
}
ویژگی های رسانه ای بیشتر
ویژگی های رسانه ای بیشتری در راه است.
ویژگیهای رسانه forced-colors
و inverted-colors
گزارش میدهند که آیا دستگاهی از یک پالت رنگ محدود یا معکوس استفاده میکند.
یک ویژگی رسانه scripting
به شما این امکان را می دهد که CSS خود را بر اساس در دسترس بودن جاوا اسکریپت تنظیم کنید.
یک ویژگی رسانه ای به نام prefers-reduced-data
به کاربران این امکان را می دهد تا مشخص کنند که در یک اتصال اندازه گیری شده هستند تا بتوانید دارایی های کوچکتر یا کمتری را ارسال کنید.
پیشنهادهای دیگر هنوز در حال تدوین است. در ماژول بعدی و نهایی، با پیشنهادی برای یک ویژگی رسانه ای آشنا خواهید شد که پیکربندی های مختلف صفحه نمایش را مدیریت می کند.
درک خود را بررسی کنید
دانش خود را از ویژگی های رسانه آزمایش کنید
یک پرسش رسانه ای می تواند دستگاهی را در عرض خاصی مانند @media (width: 1024px)
بررسی کند؟
یک پرسش رسانه ای می تواند دستگاهی را با aspect-ratio
خاص مانند @media (aspect-ratio: 4/3)
بررسی کند؟
پرس و جوهای رسانه رنگی معتبر کدامند؟
@media (monochrome)
@media (dynamic-range: high)
@media (color-gamut: srgb)
@media (min-color-index: 15000)
@media (color)
کدام یک از پرس و جوهای رسانه ترجیحی کاربر زیر معتبر است؟
@media (prefers-reduced-motion: reduce)
@media (prefers-colors: high-definition)
@media (prefers-site-speed: fast)
@media (prefers-contrast: more)
@media (prefers-color-scheme: dark)