تکنیک‌های CSS برای ساخت تصاویر Responsive
ﺯﻣﺎﻥ ﻣﻄﺎﻟﻌﻪ: 3 دقیقه

تکنیک‌های CSS برای ساخت تصاویر Responsive

به عنوان یک توسعه دهنده وب، احتمال بالایی وجود دارد که شما با دو دشمن در این مقاله رو در رو شده باشید: تصاویر و deadlineها. گاهی اوقات، تصاویر شما به دلایلی با طرح اصلی تطابق ندارند و شما نمی‌خواهید چندین ساعت وقت خود را بر روی این مسئله صرف کنید.

این موقعیت بارها برای من پیش آمده است و من از اشتباهات خود درس گرفته‌ام. در اینجا تکنیک‌های مورد علاقه من برای تغییر سایز عکس را مشاهده می‌نمایید.

روش سریع

ساعت ۵ غروب روز جمعه است، و شما کار صفحه خود را به پایان رسانده‌اید، اما تصاویر با طرح تطابق ندارند. وقت آن می‌رسد که از حقه جادویی استفاده کنید!

.myImg {
  background-image: url("my-image.png");
  background-size: cover;
}

آیا این کد آشنا به نظر می‌رسد؟ همه ما حداقل یک بار از آن استفاده کرده‌ایم.

استفاده از ویژگی background بسیار پرکاربرد است. همچنان، به یاد داشته باشید که بهتر است فقط از آن‌ها برای تصاویر غیر محتوایی، یا به عنوان جایگزینی برای متن در برخی موارد خاص استفاده کنید.

روشی از آینده

اگر به شما بگویم که این نوع جادو برای عناصر هم وجود دارد چه؟ به object-fit سلام کنید، که محض اطلاع برای ویدیوها هم کار می‌کند.

.myImg {
  object-fit: cover;
  width: 320px;
  height: 180px;
}

دقت کنید که وقتی مقدار cover را دریافت می‌کنیم، از contain هم می‌توانیم استفاده کنیم.

خب، مشکل چیست؟

متاسفانه object-fit بر روی اینترنت اکسپلورر و نسخه‌های قدیمی‌تر Safari کار نمی‌کند، اما ما polyfill را داریم.

مشاهده کد بر روی codepen.io:

روش «Netflix»

ممکن است فکر کنید: «عالی است! یک روش دیگر که در مرورگرهای قدیمی مانند اینترنت اکسپلورر کار نمی‌کند.» نگران نباشید، این مورد همه جا کار می‌کند و روش مورد علاقه من است. شما باید تصویر خود را با یک والد (parent) pad شده مرتبط، جمع‌بندی کنید.

ما نسبت تصویر را با استفاده از درصد بر روی ویژگی padding نگه خواهیم داشت. تصویر شما یک فرزند (child) در سایز کامل مطلق خواهد بود.

کد مورد نظر چنین ظاهری دارد:

.wrapper {
  position: relative;
  padding-top: 56.25%; /* 16:9 Aspect Ratio */
}

img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: auto;
}

این کد کمی پیچیده به نظر می‌رسد. پس از این که مفهوم آن را درک کنید، این تکنیک ساده خواهد شد.

پیش نمایشی بر روی codepen.io:

روش ساده

شما ممکن است از قبل این مورد را بشناسید:

img {
  height: auto;
  width: 100%;

/* با استفاده از این مورد حتی کنترل بیشتری داشته باشید */
  max-width: 720px;
}

اگر طرح شما زیاد پیچیده نیست، این روش در اکثر مواقع کار می‌کند.

روش کارآمد (و حرفه‌ای)

منظور من از کارایی، زمان بارگذاری است. یک تصویر بزرگ می‌تواند صفحه شما را نابود کند و به خصوص بر روی موبایل، آن را کند نمایش دهد.

آیا می‌دانستید که بر روی مرورگرهای مدرن شما می‌توانید بر حسب عرض صفحه خود، منبع تصویر را تغییر دهید؟ srcset به همین علت ساخته شده است.

شما می‌توانید آن را با تگ در HTML 5 ترکیب کنید، که به خوبی با یک سازگار است.


  
  
  

مشاهده کد بر روی codepen.io:

خلاصه

  1. اگر تصویر شما بخشی از محتویات صفحه نیست، از background-image استفاده کنید.
  2. اگر اینترنت اکسپلورر برای شما مهم نیست، از object-fit استفاده کنید.
  3. تکنیک محفظه pad شده که توسط Netflix هم استفاده شده است، همه جا کار می‌کند.
  4. در اکثر مواقع، فقط height: auto; را در CSS خود اضافه کنید.
  5. اگر زمان بارگذاری سریعی لازم دارید، از srcset برای بارگذاری تصاویر کوچک‌تر بر روی موبایل استفاده کنید.

منبع

چه امتیازی برای این مقاله میدهید؟

خیلی بد
بد
متوسط
خوب
عالی
3 از 1 رای

/@er79ka

دیدگاه و پرسش

برای ارسال دیدگاه لازم است وارد شده یا ثبت‌نام کنید ورود یا ثبت‌نام

در حال دریافت نظرات از سرور، لطفا منتظر بمانید

در حال دریافت نظرات از سرور، لطفا منتظر بمانید