• پایان فعالیت بخشهای انجمن: امکان ایجاد موضوع یا نوشته جدید برای عموم کاربران غیرفعال شده است

ساده ترین راه حل برای داشتن فوتر ثابت در طراحی سایت

nooshin88

Registered User
تاریخ عضویت
30 دسامبر 2015
نوشته‌ها
87
لایک‌ها
18
سن
36
در این مقاله آموزشی سعی داریم تا یک تکنولوژی جدید و کاربردی را در حوزه طراحی سایت بررسی کنیم. استفاده از این تکنولوژی، فوترهایی امن و مطمئن را برای ما تضمین خواهد کرد. بدین صورت که با وجود هر میزان محتوای سایت، فوتر ما در پایین صفحه وب‌سایت به صورت ثابت قرار خواهد گرفت.

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

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

صفحه نمایش ما، شامل هدر، بخش اصلی و فوتر می‌باشد.

در متن پایین،کدهای html نشان داده شده‌اند که هیچ چیز فوق‌العاده‌ و اضافه‌ای در آن‌ها وجود ندارد.
کد:
<body>
 <header>...</header>
<section class="main-content">...</section>
<footer>...</footer>
</body>
جهت فعال کردن تکنولوژی فلکس باکس کافی است برای body دستور display:flex را قرار دهید و flex-direction را به مقدار column تغییر دهید ( به صورت پیش‌فرض مقدار آن row است که یک لایه افقی است.) از طرفی دیگر، هم برای تگ html و هم برای تگ body می‌بایست height را برابر 100% قرار دهیم، با این‌کار کل صفحه نمایشی ما به لحاظ عمودی پر می‌شود.
کد:
html{
 height: 100%;
}
body{
 display: flex;
 flex-direction: column;
 height: 100%;
}
حال وقت آن است که تنظیمات لازم را جهت تعیین میزان فضای اشغالی برای هر بخش مشخص کنیم. ما این‌کار را می‌توانیم به کمک ویژگی‌های تعریف شده برای فلکس‌باکس انجام دهیم.
این سه مشخصه برای فلکس باکس را می‌توان باهم و به صورت یک دستور نوشت:
Flex-grow: مشخص می‌کند چه میزان از فضای خالی آزاد در container برای یک عنصر اختصاص داده شود.
Flex-shrink: مشخص می‌کند در زمانی‌که فضای کافی برای تمامی عناصر وجود ندارد، یک عنصر به چه میزان کوچک شود.
Flex-basis: اندازه پیش‌فرض برای یک عنصر.

ما انتظار داریم تا بخش هدر و فوتر وب‌سایت ما تنها به میزانی که نیاز دارند، فضا اشغال کنند و باقی فضای موجود برای محتوای اصلی سایت ما ذخیره شود.
دستورات CSS مربوط به لایه‌های فوق‌الذکر همانند دستورات زیر خواهد بود:
کد:
header{
 /* We want the header to have a static height,
 it will always take up just as much space as it needs.  */
  /* 0 flex-grow, 0 flex-shrink, auto flex-basis */
 flex: 0 0 auto;
}
.main-content{
 /* By setting flex-grow to 1, the main content will take up
all of the remaining space on the page.
 The other elements have flex-grow: 0 and won't contest the free space. */
 /* 1 flex-grow, 0 flex-shrink, auto flex-basis */
 flex: 1 0 auto;
}
footer{
 /* Like the header, the footer will have a static height - it shouldn't grow or shrink.  */
/* 0 flex-grow, 0 flex-shrink, auto flex-basis */
 flex: 0 0 auto;
}
برای آنکه نحوه عملکرد این تکنولوژی را ببینید کافی است بر روی دکمه دمو که در پایین مقاله قرار گرفته‌است، کلیک نمایید.
با کمک دکمه صورتی رنگی که در فایل دمو برای شما تهیه شده‌است می‌توانید محتوای موجود در سایت را تغییر دهید. این دکمه به شما کمک خواهد کرد که چگونگی تطبیق لایه‌ها و هدایت فوتر به انتهای صفحه را با توجه به میزان محتوای سایت به خوبی درک کنید.
نتیجه‌گیری
همان‌طور که مشاهده می‌کنید تکنولوژی فلکس باکس در حوزه طراحی سایت بسیار قدرتمند ظاهر شده‌است. تمامی مرورگرهای شناخته‌شده و مرسوم آن را پشتیبانی می‌کنند. البته استثناء کوچکی نیز وجود دارد و آن این است که این ویژگی در مرورگرهای IE9 به بالا بصورت امن اجرا خواهد شد.
برای دیدن دمو کلیک کنید.
دانلود فایل
منبع: طراحی سایت فروشگاهی ستروکیت
 
بالا