PDA

View Full Version : ویجت ها در فلاتر و انواع آن



hharddy
پنج شنبه 14 اردیبهشت 1402, 22:16 عصر
ویجت در فلاتر (Widget in Flutter) مفهومی مهم است که به عنوان سازماندهی اصلی و اجزای متحرک اصلی در برنامه‌های فلاتر مورد استفاده قرار می‌گیرد.

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

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




ویجت‌های مبتنی بر مواد(Material-based Widgets): که معمولاً در برنامه‌های طراحی شده برای محیط کاربری اندروید استفاده می‌شوند. مثال‌هایی از این ویجت‌ها عبارت‌اند از: RaisedButton، TextField و Checkbox.
ویجت‌های کوچک (Non-Material-based Widgets): که عموماً در برنامه‌های طراحی شده برای iOS استفاده می‌شوند. مثال‌هایی از این ویجت‌ها عبارت‌اند از: CupertinoButton، CupertinoTextField و CupertinoSwitch.


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



154633


در فلاتر، انواع مختلفی از ویجت‌ها برای ساخت UI وجود دارند که به صورت کلی به دو دسته می‌توان آنها را تقسیم کرد:




ویجت‌های مبتنی بر مواد (Material-based Widgets): این ویجت‌ها شامل اجزای UI مرتبط با طراحی مواد است که توسط گوگل برای اندروید طراحی شده‌اند. برخی از ویجت‌های مبتنی بر مواد عبارت‌اند از:



AppBar: برای نمایش عنوان صفحه و دکمه‌های ناوبری
FloatingActionButton: برای نمایش دکمه‌های عملیات اصلی
Card: برای نمایش اطلاعات درون یک جعبه
ListTile: برای نمایش اطلاعاتی مانند عنوان و توضیحات در فهرست



ویجت‌های کوچک (Non-Material-based Widgets): این ویجت‌ها شامل اجزای UI کوچک و ساده‌ای هستند که به صورت پیش‌فرض برای iOS طراحی شده‌اند. برخی از ویجت‌های کوچک عبارت‌اند از:



CupertinoButton: برای نمایش دکمه‌های iOS شبیه‌سازی شده
CupertinoTextField: برای نمایش جعبه‌های متنی با سبک iOS
CupertinoAlertDialog: برای نمایش پیام‌های هشدار در سبک iOS



علاوه بر این دسته‌بندی، در فلاتر (https://flutter-learn.ir/product/%d8%af%d9%88%d8%b1%d9%87-%d8%ac%d8%a7%d9%85%d8%b9-%d8%a7%d8%b3%d8%aa%d8%a7%d8%af%db%8c-%d9%81%d9%84%d8%a7%d8%aa%d8%b1-flutter/)ویجت‌هایی وجود دارند که به عنوان اجزای UI سفارشی در برنامه‌ها استفاده می‌شوند. از این ویجت‌ها می‌توان به Container، Image، Text و غیره اشاره کرد. همچنین، در فلاتر می‌توانید با استفاده از ویجت‌های مرتبط با توابع شماره‌گذاری، تقویم و نمودار، اطلاعات گوناگون را نمایش دهید.


در فلاتر، ویجت‌ها را می‌توان از نظر حالت (state) به دو دسته تقسیم کرد:



ویجت‌های بدون حالت (Stateless Widgets): این ویجت‌ها شامل ویجت‌هایی هستند که هیچگونه حالت یا داده‌ای را درون خود ذخیره نمی‌کنند و تنها برای نمایش اجزای UI به کار می‌روند. به عبارت دیگر، در صورت تغییر حالت برنامه، این ویجت‌ها هیچ تاثیری بر روی UI نخواهند داشت. برخی از ویجت‌های بدون حالت عبارت‌اند از:



Text
Icon
Image
IconButton
RaisedButton
FlatButton



ویجت‌های با حالت (Stateful Widgets): این ویجت‌ها شامل ویجت‌هایی هستند که حالت یا داده‌ای را درون خود ذخیره می‌کنند. هنگامی که حالت یک ویجت تغییر می‌کند، ویجت با مجدد رسم شدن با استفاده از داده‌های جدید، UI را به روز می‌کند. برخی از ویجت‌های با حالت عبارت‌اند از:



TextField
CheckBox
Radio
Switch
Slider
DropdownButton


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



منبع: مرجع فارسی فلاتر (https://flutter-learn.ir/) , فلاتر چیست (https://flutter-learn.ir/%d9%81%d8%b1%db%8c%d9%85%d9%88%d9%88%d8%b1%da%a9-flutter-%da%86%db%8c%d8%b3%d8%aa%d8%9f/)؟