نگاهی کوتاه بر نسخه جدید فریمورک Foundation

فریمورک Foundation محصول کمپانی ZURB هست و مثل فریمورک‌های دیگر مانند bootstrap برای توسعه front-end به کار میرود. اما به جرئت می‌توان گفت یکی از پیشرفته‌ترین فریمورک‌هایی هست که در این زمینه منتشر می‌شود، و به تازگی نسخه 6 آن منتشر خواهد شد. تمرکز اصلی فاندیشن بر روی ساخت چارچوبی است که به شما کمک می‌کند تا با سرعت بیشتری از نمونه اولیه تا تولید محصول پیش بروید. در نسخه جدید پیشرفت‌هایی حاصل شده، مانند کاهش 50 درصدی در مقدار کدها اما پیشرفتهایی دیگری نیز وجود دارند که کمک می‌کنند تا شما بیشتر و سریعتر از قبل حرکت کنید. در این مطلب نگاه کوتاهی داریم به چند پیشرفت قابل توجه :

قابلیت‌های بیشتر و بهتر برای ساخت منو (navigation)

پایه و اساس تمامی پایگاه‌های اینترنتی بزرگ، نوار ناوبری (منوی) و نحوه هدایت آن است. با وجود اینکه نقشه و پیوندها و یک سری سلسه مراتب کمک می‌کنند تا شما به یک طراحی خوب برسید اما، فریمورک‌ها نیز می‌بایست با ایجاد برخی راه‌های میانبر به شما در ناوبری سایت کمک کند. ما برای این کار از Top Bar  در فاندیشن 5 استفاده می‌کردیم، در نسخه 5 این بخش دارای پایه و اساس خوبی بود، یک منو و فهرست کشویی کاربردی که دارای دو بخش چپ و راست بود که به شکلی جادویی به فهرست و منویی مناسب برای موبایل و دستگاه‌های کوچکتر نیز تغییر حالت می‌داد. با این حالت نکته منفی برای آن این است که پیکربندی آن مشکل و کمی دشوار است و برای سفارشی‌سازی آن نیز چالش‌های زیادی را پیش رو داشتیم.

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

  • فهرست درون خطی (Inline list)
  • نوار پیمایش کناری (Side nav)
  • نوار آیکون (Icon bar)
  • نوار زیرمنو (Sub nav)

شما می‌توانید با چند دستکاری ساده تغییرات قابل توجه را انجام دهید:

  • می‌توانید آن را عمودی کنید – سپس منوهای کشویی را بیفزایید (flyouts).
  • می‌توانید تراز پیوندها را از سمت راست یا چپ بچینید یا به طور مساوی پخش کنید.
  • و یا از منوی‌های dropdowns و drilldowns یا از منوی آکاردئونی استفاده کنید.

اگر منو را با کلاس جدید .top-bar  درست کنید می‌توانید :

  • یک منوی بالایی با پس زمینه دلخواه ایجاد کنید.
  • و از فرم‌ها و دکمه‌ها (buttons) نیز داخل منو  بهره ببرید.

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

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

ابزاری قدرتمند برای اینکه پلاگین‌های خود را داشته باشید

blueprint3

یکی از راه‌هایی که برای کاهش کدهای نوشته شده در پلاگین‌های JS، این بود که آن را به کاربردهای کوچکتری تقسیم شوند که رویدادهایی (events) که در پلاگین‌های بزرگ روی می‌دهند را اداره کنند. با ساخت این پلاگین‌ها به صورت عمومی، شما می‌توانید از آنان برای ساخت پلاگین خود استفاده کنید.

Universal Toggler API:تبدیل کلاس‌ها با یک ویژگی-داده. مثال:

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

ImNotTouchingYou: یک تابع عموی برای تعیین برخورد با لبه کانتینرها. این تشخیص لبه تولتیپ‌ها یا بازشونده‌های کشویی و … را در viewport یا کانتینر انتخابی شما حفظ خواهد کرد.
IseeYou: یک تابع public برای اضافه کردن اتفاق onescroll به صورت listener به ‘window’ روش نوشتنش هم راحته؛ [DATA-SCROLL=idOdElemnt]

IhearYou: تابعی برای افزودن اتفاق resize به ‘window’

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

 

Panini: یک ابزاری جدید

blueprint4
به عنوان یک استودیو، ZURB از فاندیشن برای ساخت هزاران پایگاه استفاده می‌کند. در فاندیشن 6 شما با یک بسته توسعه یافته آشنا می‌شوید با نام Panini. در واقع Panini به شما در جهت بهینه‌سازی کد و روند کارتان کمک می‌کند. این سیستم که از Glup قدرت گرفته و می‌تواند کارهای زیادی انجام دهد:

  • کامپایل Sass به CSS
  • فایل‌های جاوا اسکریپت را به یک فایل ترکیب کند.
  • قالب‌های HTML را به صفحات و موراد جزئی تبدیل کند.

همچنین در زمان انتشار محصول نهایی می تواند کارهای زیر را برای شما انجام دهد:

  • کامپایل کردن CSS
  • استفاده از UnCSS برای حذف کلاس‌های بلا استفاده از CSS شما
  • فشرده‌سازی جاوا اسکریپت
  • فشرده‌سازی تصاویر

و یک از قابلیت‌های بسیار کاربردی آن، امکان نوشتن کدهای دینامیک برای صفحات استاتیک است. مثلا: افزودن یک کلاس active به صفحهٔ جاری:

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

تکرار تکه‌ای از HTML برای پر کردن نمونه اولیه:

یکی از برتری‌های اصلی فریمورک فاندیشن این هست که خود شرکت تولید کننده اون یعنی ZURB از اون برای توسعه سفارش‌ها و کارهای حرفه‌ای خودش استفاده می‌کند و در عین حال اون رو برای عموم هم به صورت بازمتن منتشر میکند. امروز (۲۸ آبان) نسخه ۶ فاندیشن رسما منتشر می‌شود. به زودی مطالب و مقالات بیشتری در این زمینه منتشر می‌کنیم. اگر از این فریمورک استفاده می‌کنید خوشحال می‌شویم تجربیات خودتان را با دیگران به اشتراک بگذارید.

پیام صادری

در حال حاضر فریلنس هستم و بیش ۱۰ سال هست که در زمینه front-end و مدیریت سرورهای لینوکس فعالیت می‌کنم. و طی این سالها تجربیاتی خوبی هم کسب کردم. یکی از طرفداران Open Source هستم و سعی می‌کنم در فعالیت‌های داوطلبانه این حوزه شرکت کنم. همیشه در حال یادگیری تکنولوزی‌های جدید هستم و از تولید پادکست و نوشتن وبلاگ لذت می‌برم.

همچنین ممکن است دوست داشته باشید ...

۲ واکنش

  1. علی گفت:

    رفقا مطالبتون خیلی عالیه.
    من به سهم خودم از زحمتتاتون قدردانی می کنم. ممنون.

  2. سهیلا گفت:

    سلام چگونه می تونم فونت فارسی به فریمورک Foundation اضافه کنم

    لطفا من رو راهنمایی کنید در حال حاضر کلمات انگلیسی رو فارسی کردم اما فونتش جالب نیست

    تشکر

پاسخ دهید

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