اصول طراحی وب سایت ریسپانسیو

همانطور که تعداد کاربران تلفن همراه در اینترنت افزایش می‌یابد، برای طراحان وب اهمیت بیشتری پیدا کرده است که محتوا را به گونه‌ای تنظیم کنند که برای اندازه‌های مختلف صفحه نمایش مناسب باشد. طراحی وب ریسپانسیو، که در اصل توسط Ethan Marcotte در A List Apart تعریف شده است، یک استراتژی طراحی است که با تغییر طرح سایت متناسب با دستگاه مورد استفاده، به نیازهای کاربران و قابلیت های دستگاه های آنها پاسخ می دهد. به عنوان مثال، یک سایت واکنش‌گرا ممکن است محتوا را به صورت تک ستونی در تلفن، دو ستون در رایانه لوحی و سه یا چهار ستون در رایانه رومیزی نشان دهد.

با بزرگتر شدن صفحه نمایش، ویجت در پاسخ تغییر شکل می دهد.

از آنجایی که دستگاه‌های دارای قابلیت اینترنت دارای اندازه‌های صفحه ممکن زیادی هستند، برای سایت شما مهم است که با هر اندازه صفحه نمایش موجود یا آینده سازگار شود. طراحی واکنش‌گرای مدرن، حالت‌های تعاملی مانند صفحه‌نمایش‌های لمسی را نیز در بر می‌گیرد. هدف بهینه سازی تجربه برای همه است.

Viewport را تنظیم کنید

صفحات بهینه سازی شده برای انواع دستگاه ها باید دارای یک تگ متا نمای در سر سند باشند. این تگ به مرورگر می گوید که چگونه ابعاد و مقیاس صفحه را کنترل کند.

برای تلاش برای ارائه بهترین تجربه، مرورگرهای تلفن همراه صفحه را با عرض صفحه دسکتاپ (معمولاً حدود 980px ، هر چند در دستگاه‌ها متفاوت است) رندر می‌دهند و سپس سعی می‌کنند با افزایش اندازه فونت و مقیاس‌بندی محتوا متناسب با آن، محتوا را بهتر جلوه دهند. صفحه نمایش این می‌تواند باعث شود که فونت‌ها ناسازگار به نظر برسند و کاربران را ملزم به بزرگنمایی برای دیدن و تعامل با محتوا کند.

<!DOCTYPE html>
<html lang="en">
  <head>
    …
    <meta name="viewport" content="width=device-width, initial-scale=1">
    …
  </head>
  …

استفاده از مقدار نمای متا width=device-width به صفحه می‌گوید که با عرض صفحه در پیکسل‌های مستقل از دستگاه (DIP) مطابقت داشته باشد، یک واحد پیکسل بصری استاندارد (که می‌تواند از بسیاری از پیکسل‌های فیزیکی در یک صفحه نمایش با چگالی بالا تشکیل شود). این به محتوای صفحه اجازه می دهد تا با اندازه های مختلف صفحه مطابقت داشته باشد.

اسکرین شات از صفحه ای که خواندن متن آن سخت است زیرا بسیار کوچک شده است.
یک صفحه بدون متا تگ viewport بارگذاری می شود که بسیار کوچک شده است و خواندن متن را سخت می کند. این مثال را در Glitch ببینید .
اسکرین شات از همان صفحه با متن در اندازه قابل خواندن.
با مجموعه متا تگ viewport، می توانید صفحه را بدون بزرگنمایی بخوانید. این مثال را در Glitch ببینید .

برخی از مرورگرها هنگام چرخش به حالت افقی، عرض صفحه را ثابت نگه می دارند و به جای جریان مجدد، برای پر کردن صفحه بزرگنمایی می کنند. افزودن مقدار initial-scale=1 به مرورگرها می‌گوید که یک رابطه 1:1 بین پیکسل‌های CSS و پیکسل‌های مستقل از دستگاه بدون توجه به جهت‌گیری دستگاه تنظیم کنند، و به صفحه اجازه می‌دهد از تمام عرض افقی استفاده کند.

تگ <meta name="viewport"> با width یا initial-scale ممیزی Lighthouse ندارد می‌تواند به شما در خودکارسازی فرآیند اطمینان از استفاده صحیح اسناد HTML از متا تگ viewport کمک کند.

اندازه محتوا به درگاه نمایش

در هر دو دستگاه دسکتاپ و موبایل، کاربران عادت دارند وب سایت ها را به صورت عمودی و نه افقی پیمایش کنند. مجبور کردن کاربر به اسکرول افقی یا کوچک نمایی برای دیدن کل صفحه باعث تجربه کاربری ضعیف می شود.

هنگام توسعه یک سایت تلفن همراه با تگ متا ویوپورت، معمولاً به طور تصادفی محتوای صفحه ای ایجاد می شود که کاملاً با نمای مشخص شده مطابقت ندارد. برای مثال، تصویری که عریض‌تر از درگاه دید نمایش داده می‌شود، می‌تواند باعث اسکرول افقی شود. برای جلوگیری از این امر، محتوای خود را طوری تنظیم کنید که در داخل پنجره نمایش قرار گیرد.

اندازه محتوا برای درگاه دید درست نیست .

تصاویر

یک تصویر با ابعاد ثابت باعث می‌شود که صفحه در صورت بزرگ‌تر بودن صفحه نمایش اسکرول شود. توصیه می‌کنیم به همه تصاویر max-width 100% بدهید، که تصاویر را به تناسب فضای موجود کوچک می‌کند و در عین حال از کشیده شدن آنها به اندازه اولیه‌شان جلوگیری می‌کند.

در بیشتر موارد، می توانید این کار را با افزودن موارد زیر به شیوه نامه خود انجام دهید:

img {
  max-width: 100%;
  display: block;
}

ابعاد تصویر را به عنصر img اضافه کنید

حتی زمانی که max-width: 100% را تنظیم می‌کنید، همچنان توصیه می‌کنیم ویژگی‌های width و height را به تگ‌های <img> خود اضافه کنید تا مرورگر بتواند قبل از بارگیری تصاویر، فضا را برای آنها رزرو کند. این به جلوگیری از تغییر طرح کمک می کند.

طرح بندی

از آنجایی که ابعاد و عرض صفحه در پیکسل‌های CSS بین دستگاه‌ها (مثلاً بین تلفن‌ها و تبلت‌ها، و حتی بین گوشی‌های مختلف) بسیار متفاوت است، محتوا نباید برای ارائه خوب به عرض درگاه دید خاصی متکی باشد.

در گذشته، این نیاز به تنظیم عناصر چیدمان بر حسب درصد داشت. با استفاده از اندازه‌گیری پیکسل، کاربر باید به صورت افقی روی صفحه‌های کوچک حرکت کند:

اسکرین شات از طرح‌بندی دو ستونی که بیشتر ستون دوم در خارج از درگاه دید قرار دارد
طرح بندی شناور با استفاده از پیکسل. این مثال را در Glitch ببینید .

استفاده از درصد به جای آن، ستون‌ها را در صفحه‌های کوچک‌تر باریک‌تر می‌کند، زیرا هر ستون همیشه درصد یکسانی از عرض صفحه را اشغال می‌کند:

تکنیک‌های چیدمان CSS مدرن مانند Flexbox، Grid Layout و Multicol ایجاد این شبکه‌های انعطاف‌پذیر را بسیار آسان‌تر می‌کنند.

فلکس باکس

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

.items {
  display: flex;
  justify-content: space-between;
}

می‌توانید از Flexbox برای نمایش آیتم‌ها به‌عنوان یک ردیف استفاده کنید، یا با کاهش فضای موجود روی چند ردیف قرار دهید.

درباره Flexbox بیشتر بخوانید .

طرح بندی شبکه CSS

CSS Grid Layout شبکه های انعطاف پذیر ایجاد می کند. می‌توانید مثال شناور قبلی را با استفاده از طرح‌بندی شبکه و واحد fr که بخشی از فضای موجود در ظرف را نشان می‌دهد، بهبود ببخشید.

.container {
  display: grid;
  grid-template-columns: 1fr 3fr;
}

همچنین می‌توانید از Grid Layout برای ایجاد طرح‌بندی‌های شبکه‌ای منظم با هر تعداد آیتم که مناسب است استفاده کنید. با کاهش اندازه صفحه، تعداد آهنگ های موجود کاهش می یابد. نسخه آزمایشی زیر شبکه‌ای را نشان می‌دهد که دارای تعداد کارت‌هایی است که در هر ردیف با حداقل اندازه 200px است.

درباره CSS Grid Layout بیشتر بخوانید

طرح چند ستونی

برای برخی از انواع طرح‌بندی، می‌توانید از طرح‌بندی چند ستونی (Multicol) استفاده کنید که تعداد ستون‌های پاسخگو با ویژگی column-width ایجاد می‌کند. در نسخه ی نمایشی زیر، صفحه ستون هایی اضافه می کند که فضایی برای ستون 200px دیگر وجود داشته باشد.

درباره Multicol بیشتر بخوانید

از پرس و جوهای رسانه ای CSS برای پاسخگویی استفاده کنید

گاهی اوقات ممکن است لازم باشد تغییرات گسترده‌تری در چیدمان خود ایجاد کنید تا از اندازه‌های صفحه‌نمایش خاصی پشتیبانی کند تا اینکه تکنیک‌هایی که قبلاً توضیح داده شد اجازه می‌دهد. اینجاست که پرس و جوهای رسانه ای مفید می شوند.

پرسش‌های رسانه فیلترهای ساده‌ای هستند که می‌توانید آن‌ها را برای سبک‌های CSS اعمال کنید تا آن سبک‌ها را بر اساس انواع دستگاه‌های ارائه‌دهنده محتوا تغییر دهید. آنها همچنین می‌توانند استایل را بر اساس ویژگی‌های دستگاه از جمله عرض، ارتفاع، جهت و اینکه آیا دستگاه به‌عنوان صفحه لمسی استفاده می‌شود، تغییر دهند.

برای ارائه سبک های مختلف برای چاپ، می توانید یک نوع خروجی را هدف قرار دهید و یک برگه سبک برای سبک های چاپ قرار دهید:

<!DOCTYPE html>
<html lang="en">
  <head>
    …
    <link rel="stylesheet" href="print.css" media="print">
    …
  </head>
  …

همچنین می‌توانید از یک درخواست رسانه برای گنجاندن سبک‌های چاپ در شیوه نامه اصلی خود استفاده کنید:

@media print {
  /* print styles go here */
}

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

پرس و جوهای رسانه بر اساس اندازه درگاه دید

پرس و جوهای رسانه ای به شما امکان می دهند یک تجربه پاسخگو ایجاد کنید که سبک های خاصی را برای اندازه صفحه نمایش خاص اعمال می کند. پرس و جوهایی برای اندازه صفحه نمایش می توانند موارد زیر را آزمایش کنند:

  • width ( min-width ، max-width )
  • height ( min-height ، max-height )
  • orientation
  • aspect-ratio

همه این ویژگی ها از مرورگر عالی پشتیبانی می کنند. برای جزئیات بیشتر، از جمله اطلاعات پشتیبانی مرورگر، عرض ، ارتفاع ، جهت و نسبت ابعاد را در MDN ببینید.

پرسش های رسانه ای بر اساس قابلیت دستگاه

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

  • hover
  • pointer
  • any-hover
  • any-pointer

سعی کنید این نسخه آزمایشی را در دستگاه‌های مختلف مانند رایانه رومیزی معمولی و تلفن یا رایانه لوحی مشاهده کنید.

این ویژگی های جدیدتر در تمام مرورگرهای مدرن پشتیبانی خوبی دارند. در صفحات MDN برای شناور ، هر نشانگر ، اشاره گر و هر اشاره گر بیشتر بیاموزید.

any-hover و any-pointer استفاده کنید

در صورتی که کاربر بتواند نشانگر را روی عناصر نگه دارد (که اغلب به آن شناور می‌گویند)، یا اصلاً از نشانگر استفاده کند، حتی اگر این روش اصلی تعامل با دستگاه خود نباشد، ویژگی‌های تست any-hover و any-pointer . هنگام استفاده از اینها بسیار مراقب باشید، برای مثال از مجبور کردن کاربر صفحه لمسی برای تغییر روی ماوس اجتناب کنید. با این حال، any-hover و any-pointer می تواند مفید باشد اگر تعیین نوع دستگاهی که یک کاربر دارد مهم باشد. به عنوان مثال، لپ تاپ با صفحه نمایش لمسی و پد لمسی، علاوه بر قابلیت شناور، باید با نشانگرهای درشت و ظریف مطابقت داشته باشد.

نحوه انتخاب نقاط شکست

نقاط شکست را بر اساس کلاس های دستگاه یا هر محصول، نام تجاری یا سیستم عاملی تعریف نکنید. این کار حفظ کد شما را دشوار می کند. در عوض، اجازه دهید محتوا تعیین کند که چگونه چیدمان آن متناسب با ظرف تغییر می کند.

نقاط انفصال اصلی را با شروع کوچک و سپس بالا بردن انتخاب کنید

ابتدا محتوا را طوری طراحی کنید که بر روی یک صفحه نمایش کوچک قرار بگیرد، سپس صفحه را تا زمانی که نقطه شکست ضروری شود، گسترش دهید. این به شما امکان می دهد تعداد نقاط شکست را در صفحه خود به حداقل برسانید و آنها را بر اساس محتوا بهینه کنید.

مثال زیر نمونه ویجت پیش بینی آب و هوا را در ابتدای این صفحه نشان می دهد. اولین گام این است که پیش بینی را در یک صفحه کوچک خوب جلوه دهید:

اسکرین شات یک برنامه آب و هوا در عرض موبایل
برنامه در عرض باریک.

در مرحله بعد، اندازه مرورگر را تغییر دهید تا فضای خالی زیادی بین عناصر وجود داشته باشد تا ویجت خوب به نظر برسد. تصمیم ذهنی است، اما بیش از 600px مطمئناً بسیار گسترده است.

اسکرین شات یک برنامه آب و هوا با فاصله زیاد بین موارد
در این اندازه، طرح‌بندی برنامه احتمالاً باید تغییر کند.

برای درج نقطه شکست در 600px ، دو درخواست رسانه در انتهای CSS خود برای مؤلفه ایجاد کنید: یکی برای استفاده زمانی که مرورگر 600px یا باریکتر است، و دیگری برای زمانی که پهنای آن از 600px بیشتر است.

@media (max-width: 600px) {

}

@media (min-width: 601px) {

}

در نهایت، CSS را دوباره فاکتور کنید. در داخل درخواست رسانه برای max-width 600px ، CSS را اضافه کنید که فقط برای صفحه نمایش های کوچک است. در داخل کوئری رسانه برای min-width 601px CSS را برای صفحات بزرگتر اضافه کنید.

در صورت لزوم نقاط شکست جزئی را انتخاب کنید

علاوه بر انتخاب نقاط شکست اصلی زمانی که چیدمان به طور قابل توجهی تغییر می کند، تنظیم برای تغییرات جزئی نیز مفید است. به عنوان مثال، در بین نقاط شکست اصلی، تنظیم حاشیه یا بالشتک روی یک عنصر، یا افزایش اندازه فونت برای ایجاد حس طبیعی تر در چیدمان می تواند مفید باشد.

این مثال از همان الگوی قبلی پیروی می کند و با بهینه سازی طرح های صفحه نمایش کوچکتر شروع می شود. ابتدا، زمانی که عرض درگاه دید بیشتر از 360px است، فونت را تقویت کنید. پس از آن، هنگامی که فضای کافی وجود دارد، می توانید دمای بالا و پایین را جدا کنید تا در یک خط قرار گیرند و نمادهای آب و هوا را بزرگتر کنید.

@media (min-width: 360px) {
  body {
    font-size: 1.0em;
  }
}

@media (min-width: 500px) {
  .seven-day-fc .temp-low,
  .seven-day-fc .temp-high {
    display: inline-block;
    width: 45%;
  }

  .seven-day-fc .seven-day-temp {
    margin-left: 5%;
  }

  .seven-day-fc .icon {
    width: 64px;
    height: 64px;
  }
}

برای صفحه‌های بزرگ، توصیه می‌کنیم حداکثر عرض پانل پیش‌بینی را محدود کنید تا از کل عرض صفحه استفاده نشود.

@media (min-width: 700px) {
  .weather-forecast {
    width: 700px;
  }
}

بهینه سازی متن برای خواندن

تئوری خوانایی کلاسیک پیشنهاد می کند که یک ستون ایده آل باید شامل 70 تا 80 کاراکتر در هر خط (حدود 8 تا 10 کلمه به زبان انگلیسی) باشد. هر بار که عرض یک بلوک متنی از حدود 10 کلمه گذشته است، یک نقطه شکست اضافه کنید.

اسکرین شات از یک صفحه متن در یک دستگاه تلفن همراه
پیامک در دستگاه تلفن همراه.
اسکرین شات از یک صفحه متن در مرورگر دسکتاپ
همان متن در یک مرورگر دسکتاپ با یک نقطه شکست برای محدود کردن طول خط اضافه شده است.

در این مثال، فونت Roboto در 1em 10 کلمه در هر خط در صفحه کوچکتر تولید می کند، اما صفحات بزرگتر نیاز به نقطه شکست دارند. در این حالت، اگر عرض مرورگر بیشتر از 575px باشد، عرض محتوای ایده آل 550px است.

@media (min-width: 575px) {
  article {
    width: 550px;
    margin-left: auto;
    margin-right: auto;
  }
}

اجتناب از پنهان کردن محتوا (:#avoid-hiding-content)

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

نقاط شکست درخواست رسانه را در Chrome DevTools مشاهده کنید

پس از تنظیم نقاط شکست درخواست رسانه خود، بررسی کنید که چگونه بر ظاهر سایت شما تأثیر می گذارد. می‌توانید اندازه پنجره مرورگر خود را تغییر دهید تا نقاط شکست را فعال کند، اما Chrome DevTools یک ویژگی داخلی دارد که نشان می‌دهد یک صفحه در نقاط شکست مختلف چگونه به نظر می‌رسد.

نماگرفت DevTools با برنامه آب و هوای ما باز و عرض 822 پیکسل انتخاب شده است.
DevTools برنامه آب و هوا را در اندازه نمای وسیع تری نشان می دهد.
نماگرفت DevTools با برنامه آب و هوای ما باز و عرض 436 پیکسل انتخاب شده است.
DevTools برنامه آب و هوا را با اندازه درگاه دید باریکتر نشان می دهد.

برای مشاهده صفحه خود در نقاط شکست مختلف:

  1. DevTools را باز کنید .
  2. حالت دستگاه را روشن کنید. این به طور پیش فرض در حالت پاسخگو باز می شود.
  3. برای مشاهده درخواست‌های رسانه خود، منوی حالت دستگاه را باز کرده و Show media quries را انتخاب کنید. این نقطه شکست شما را به صورت نوارهای رنگی بالای صفحه شما نشان می دهد.
  4. در حالی که درخواست رسانه فعال است، روی یکی از نوارها کلیک کنید تا صفحه خود را مشاهده کنید. روی یک نوار کلیک راست کنید تا به تعریف آن درخواست رسانه بروید.