طراحی وبسایت واکنش گرا

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

برای ایجاد یک وبسایت واکنش گرا دانستن چند نکته ضروری است که در این نوشته به اختصار آن‌ها را مرور می‌کنیم.

Viewport

مرورگرهای موبایل برای سازگاری با سایت‌هایی که در گذشته طراحی شده‌اند، از مفهومی به نام Viewport برای نمایش سایت‌ها استفاده می‌کنند. Viewport فضایی مجازی است که معمولا حدود ۱۰۰۰ پیکسل عرض دارد. مرورگر موبایل سایت را در این فضای مجازی نمایش می‌دهد و سپس این تصویر را در فضای واقعی نمایشگر موبایل یا تبلت قرار می‌دهد که اگر از عرض صفحه ی نمایش موبایل بزرگتر باشد، کاربر می‌بایست صفحه را به راست و چپ حرکت دهد تا تمام محتوای سایت را مشاهده کند.

نخستین گام در طراحی سایت واکنش گرا، اطلاع رسانی به مرورگر برای تغییر اندازه‌ی Viewport است تا به جای ۱۰۰۰ یا ۹۸۰ پیکسل پیش‌فرض، فضای مورد نظر برنامه‌نویس را به Viewport اختصاص دهد.
تغییر اندازه‌ی Viewport با استفاده از تگ meta در سرآمد فایل html به انجام می‌رسد.

<head>
<meta name="viewport" content="width=480">
</head>

همان‌گونه که مشاهده می‌کنید، در مثال بالا عرض Viewport برابر ۴۸۰ پیکسل مشخص شده است. در این روش، عرض Viewport در دستگاه‌های مختلف ثابت خواهد بود و ممکن است در تبلت‌ها که عرض بیشتری دارند، متن‌ها و تصویرها بیش از اندازه بزرگ باشند.
شیوه‌ی دیگر در تغیین مقدار Viewport، تعیین آن با عرض فیزیکی نمایشگر است. برای این کار از کد زیر استفاده می‌شود:

<meta name="viewport" content="width=device-width">

با انجام این کار عرض Viewport مطابق عرض صفحه‌ی موبایل یا تبلت تغییر خواهد کرد.

اندازه‌ی مجازی

به دلیل تراکم بیشتر پیکسلی در موبایل‌های امروزی در مقایسه با تراکم متداول در نمایشگرهای لپ‌تاپ و کامپیوترهای شخصی، مرورگرهای موبایل ممکن است هر پیکسل را بزرگتر از یک پیکسل به نمایش درآورند. به این معنی که مثلا اگر عرض یک عنصر ۲۰۰ پیکسل مشخص شود، ممکن است این مقدار مساوی ۴۰۰ پیکسل به نمایش درآید.
درصد بزرگنمایی پیکسل در مرورگرهای مختلف و در دستگاه‌های مختلف و در سیستم‌عامل‌های مختلف، متغیر است. بنابراین یکی از مهم‌ترین نکات در طراحی سایت واکنش گرا، عدم اعتماد به انداز‌ه‌ی پیکسل‌ها است.
در سایت Screen Sizes می‌توانید اندازه‌ی واقعی و مجازی پیکسل در ابزارهای مختلف را مشاهده کنید.
برای مثال گوشی Galaxy SII دارای ۴۸۰ پیکسل واقعی و ۳۲۰ پیکسل مجازی است. به عبارت دیگر، اگر شما یک تصویر با عرض ۳۲۰ پیکسل را در این گوشی به نمایش در بیاورید، این تصویر ۴۸۰ پیکسل فضا اشغال خواهد کرد.
بهترین راه حل برای پایداری طرح، استفاده از واحدهای فیزیکی مانند point، cm، و ... است

بزرگنمایی

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

<meta name="viewport" content="width=480, initial-scale=1, maximum-scale=2">

در کد بالا بیشترین اندازه‌ی بزرگنمایی ۲ برابر و اندازه‌ی پیش‌فرض آن ۱ تعیین شده است.

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

عرض حداقل و حداکثر

برای آنکه صفحات وب در همه‌جا به بهترین شکل ممکن نمایش داده شوند، لازم است تا عرض حداقل و حداکثر برای عنصر body تعیین شود. با توجه به جدول سایت Screen Sizes که بالاتر مشاهده کردید، حداقل عرض مجازی می‌تواند ۳۲۰ پیکسل و با توجه به آخرین آمار استفاده کنندگان لپ‌تاپ و کامپیوتر، حداکثر عرض مناسب، ۱۰۰۰ پیکسل است. البته ممکن است با توجه به تقسیم‌پذیری بهتر ۹۶۰ در مقایسه با ۱۰۰۰، بخواهید از این عدد استفاده کنید.

دید جعبه‌ای یا بر پایه‌ی ماژول

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

ویژگی‌های خاص شیوه‌نامه‌های CSS برای پیاده‌سازی طرح واکنش گرا

مهم‌ترین ویژگی CSS برای پشتیبانی طراحی سایت واکنش گرا، دستور media است. این دستور به ما کمک می‌کند تا بر اساس عرض صفحه، ویژگی‌های عنصرهای دلخواه خود را تغییر دهیم. min-width و max-width در مقابل media ابزارهایی هستند که بسیار ما را یاری خواهند داد:

@media ( min-width: 1000px ) {
	footer {
		width: 1000px;
	}
}
@media ( min-width: 401px ) {
	footer {
		display: block;
	}
}
@media ( max-width: 400px ) {
	footer {
		display: none;
	}
}

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

تصویرها

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

بهتر است اندازه‌ی تصویر مساوی بزرگترین اندازه‌ی پیکسل‌های واقعی نمایشگر کامپیوتر در نظر گرفته شود. برای مثال عدد ۱۰۰۰ یا ۱۳۶۶ می‌تواند مقدار مناسبی باشد.

در نمایشگرهای کوچکتر، با تعیین اندازه‌ی درصدی عرض و تعیین نکردن ارتفاع یا قرار دادن مقدار auto برای آن می‌توان یک تصویر واکنش گرا در اختیار داشت

img#header {
	width: 100%;
	height: auto;
}

تغییر اندازه‌ی تصاویر پس‌زمینه هم در css به شکل زیر انجام می‌شود:

div#header {
	width: 100%;
	padding-top: 50%;
	background-image: url( "01.jpg" );
	background-repeat: no-repeat;
	background-size: 100% auto;
}

نکته‌ی قابل توجه در قطعه کد بالا، استفاده از padding-top برای مشخص کردن ارتفاع div است. با توجه به اینکه معیار padding عرض عنصر والد است. با کمک آن می‌توان، ارتفاع یک عنصر را به صورت Responsive تعیین کرد.

اندازه‌ی فونت‌ها

بهترین واحد برای مشخص کردن، اندازه‌ی فونت‌ها واحدهای فیزیکی هستند. برای مثال تعیین اندازه‌ی فونت پیش‌فرض صفحه با مقدار "14pt" به جای "14px" و تعیین اندازه‌ی عنصرهای داخلی بر اساس «درصد» یا «em» راه حلی مطمئن برای داشتن نوشته‌های واکنش گرا است.
برای آشنایی با واحدهای اندازه‌گیری در طراحی وب می‌توانید این نوشته را مطالعه کنید

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

۴۷ نظر در مورد «آموزش طراحی سایت واکنش گرا( Responsive WebDesign )»

    • امیرمسعود ایرانی می‌گوید:

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

      • سلام و خسته نباشید خدمت شما مسعود عزیز.
        یک سایت را طراحی کردم و میخواهم آن را responsive بسازم
        آموزش responsive را در اینترنت هر چی جستجو کردم نتوانستم پیدا کنم.
        اگر کتاب آموزشresponsive را به زبان فارسی در دسترس دارید لطف نموده به
        ایمیل آدرس:r.alizada@kpu.edu.af ارسال نموده ممنون سازید.

        • امیرمسعود ایرانی می‌گوید:

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

  • سلام و تشکر بابت مطلبتون...یه سوال داشتم....من این طور متوجه شدم که در طراحی ریسپانسیو ما باید چند بار کد سی اس اس رو برای هر دیو و عناصر داخل صفحه استفاده کنیم که مثلا توی عرض صفحه کمتر از 720پیکسل این دیو من عرضش چقدر باشه و همون دیو توی عرض صفحه کمتر از 400 عرض چقدر باشه.....درست متوجه شدم(اگر درست متوجه شدم یه سوال دیگه اینکه من برای تمام عناصر باید مقدار قرار بدم یعنی این که چند مدل سی اس اس دارم ؟)

    • امیرمسعود ایرانی می‌گوید:

      با سلام

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

  • سلام. سایت من در بازدید اول روی مانیتورم،‌ صفحه رو کامل نشون نمی‌ده! وقتی که کنترل منها یا با کنترل ماوس صفحه رو کوچکتر میکنیم سایدبار راست رو نمایش میده! اینطوری سایتم خیلی ناقص میشه! چه کدی رو باید حذف کنم که سایتم ریسپانسیو نباشه؟ یا باید چیکار کنم که در بازدید اول صفحه‌ی کامل بیاد اما ریسپانسیو هم باشه؟ ممنون

    • امیرمسعود ایرانی می‌گوید:

      با سلام
      بدون دیدن کد نمی‌شه در مورد اشکال سایت شما نظری داد.
      تغییر دادن کدها هم ممکنه زمان زیادی نیاز داشته باشه
      پیشنهاد می‌کنم اگر در انجام این کار تجربه‌ی کافی رو ندارید از یک نفر که در این مورد بیشتر کار کرده باشه کمک بگیرید تا اشکال‌های ریسپانسیو سایت شما را برطرف کنه
      با تشکر

  • افشین می‌گوید:

    بسیار عالی
    بنظر شما برای اجرای سایت واکنشگرا روی اینترنت اکسپلور های 7و8 باید چه کار کرد لطفا راهنمایی کنید.

    • امیرمسعود ایرانی می‌گوید:

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

  • افشین می‌گوید:

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

    • امیرمسعود ایرانی می‌گوید:

      با سلام

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

  • سلام
    من فکر می کنم این همه آدمی که اینجا از شما تشکر کردند یک بار هم مطلب شما رو استفاده نکردند.اونها هم استفاده نکردند که هیچ شما خودتون هم یه بار اونو تست نکردین و فقط این مطلب رو از سطح وب کپی کردین.

    • امیرمسعود ایرانی می‌گوید:

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

    • امیرمسعود ایرانی می‌گوید:

      دلیلی برای ناراحتی وجود نداره
      البته من نتونستم ارتباط منطقی بین نوشتن یک مقاله در مورد ریسپانسیو و ریسپانسیو بودن وبلاگم پیدا کنم.

    • امیرمسعود ایرانی می‌گوید:

      با سلام

      تبدیل یک سایت به Mobile Friendly یا Responsive همون طور که در نوشته‌ی بالا توضیح داده شده، به مراحل زیادی نیاز داره
      و اولین قدم اینه که در ذهن خودتون تصور کنید اگر عرض صفحه کمتر باشه، مشتری چه محتوایی رو باید ببینه، چه محتوایی رو نباید ببینه و محتوایی که باید ببینه به چه شکلی باشه.
      و مرحله‌ی بعد اینه که مطالعه‌ی خودتون رو در مورد طراحی سایت واکنش‌گرا افزایش بدید و تغییراتی که در مرحله‌ی قبل طراحی شده رو روی سایتتون پیاده کنید
      اگر در این زمینه تجربه‌ای ندارید، و کسب و کار شما هم چیز دیگری است، شاید بهتر باشه که از یک نفر متخصص این کار کمک بگیرید
      با تشکر

    • امیرمسعود ایرانی می‌گوید:

      با سلام و تشکر از لطفا شما
      در ضمن جهت اینکه شائبه‌ای پیش نیاید که خواسته باشید با درج کامنت،
      تبلیغ سایت خودتان را بکنید، اسم سایتتان را به example.com تغییر دادم

  • مطالب شما خیلی مفید بود.

    من در حال حاضر یک جدول بزرگ دارم ولی نمیدانم چگونه واکنش گرا باید کرد?
    شما میتوانید من را راهنمایی کنید?
    مرسی برای زحمتهایتان

    • امیرمسعود ایرانی می‌گوید:

      با سلام

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

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

    • امیرمسعود ایرانی می‌گوید:

      سلام و تشکر
      نگارش‌های قدیمی IE از media پشتیبانی نمی‌کنند. برای در اختیار داشتن یک سایت responsive تنها با CSS باید پشتیبانی از مرورگرها را محدود کنید. درصد استفاده از نگارش‌های قدیمی IE بسیار کم شده است و کسانی که از این مرورگر استفاده می‌کنند با بسیاری از سایت‌های دیگر هم مشکل دارند بنابراین جای نگرانی وجود ندارد

        • امیرمسعود ایرانی می‌گوید:

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

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

    • امیرمسعود ایرانی می‌گوید:

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

  • سلام
    با دریم ویور ccمیخوام سایت واکنش گرا درس کنم اما فقط ایکون pcوجود داره ایکون های تبلت و موبایل نیست میگه اینترنت و روشن کن روشنم میکنم میگه شما دسترسی نداری
    مشکل کجاست؟

    • امیرمسعود ایرانی می‌گوید:

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

    • امیرمسعود ایرانی می‌گوید:

      با سلام
      ریسپانسیو کردن قالب وردپرس با افزونه امکان‌پذیر نیست و باید در طراحی قالب به انجام برسه
      در ضمن به دلیل اینکه اسمتون رو اشتباه تایپ کرده بودید، نشانی سایتتون حذف شد

  • وب کندو می‌گوید:

    واقعا ممنون بابت اطلاعات جالبی که دادین من درباره viewport و موبایل زیاد چیزی نمیدونستم اما الان کاملا متوجه شدم که نقش اینها تو طراحی سایت چیه

    • امیرمسعود ایرانی می‌گوید:

      واقعا باعث تاسفه که شرکت وب کندو در مورد viewport و موبایل چیزی نمی‌دونه و بدتر از اون اینکه برای تبلیغات اینترنتی کامنت‌های اسپم توی وبلاگ دیگران ارسال می‌کنه

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *