Flutter Zone | فلاتر و دارت – Telegram
Flutter Zone | فلاتر و دارت
776 subscribers
520 photos
311 videos
1.07K files
811 links
ناحیه‌ی فلاتر
برای فلاتر
اموزش های فلاتر و دارت از یودمی

لینک گروه : https://news.1rj.ru/str/flutterzone_group
Download Telegram
Forwarded from Pure Coder
⚡️چرخه حیات State ، مختصر ، کامل و دقیق⚡️

1⃣mount
اولین بار که یک stateful ساخته میشه و توی درخت قرار میگیره متد های زیر از state به ترتیب اجرا میشن :
State Constructor

initState
didChangeDependencies
build

توی هر سه متد بالا به context دسترسی داریم و میتونیم با context کار کنیم.
برخلاف تصور و اشتباه رایج خیلی ها که میگن داخل initState به context دسترسی نداریم.
🔥فقط اگه میخاستیم به یه inheritedWidget وابسته بشیم مثلن theme.of رو صدا بزنیم این کار رو باید توی دو متد didChangeDependencies یا build انجام بدیم.
🔥همیچنین توی متد های بالا با استفاده از پروپرتی widget میتونیم به ویجت این State دسترسی داشته باشیم.

2⃣setState
هر بار که توی استیت setState صدا زده بشه متد build یکبار دیگه اجرا میشه.

3⃣update
هر بار که ویجت parent این stateful این ویجت رو با یه کانفیگ جدید اپدیت کنه متدهای زیر اجرا میشن :
didUpdateWidget (Widget oldWidget)
build

ویجت parent این ویجت اپدیت شده و child خودش که همین stateful ما هست رو با یه ویجت جدید از همین type اپدیت کرده (ویجت ها immutable هستن)
در نتیجه didUpdateWidget اجرا میشه که به state اطلاع بده که ویجتت اپدیت شده.
توی ورودی هم ویجت قبلی (stateful قبلی /oldWidet) رو بهش میده.
ویجت جدید هم از طریق پروپرتی widget قابل دسترسیه.

4⃣dependencies changed
اگه این ویجت به یه InheritedWidget وابسته شده باشه مثلن Theme.of رو با context خودش صدا زده باشه.
هر بار که اون InheritedWidget اپدیت بشه و این اپدیت شدن رو به درخت زیر خودش نوتیف بده متد های زیر به ترتیب اجرا میشن :
didChangeDependencies
build

5⃣deactivate
هر بار که ویجت parent این ویجت تصمیم بگیره این نقطه از درخت رو با یه ویجت جدید جایگزین کنه یا کلن این ویجت رو حذف کنه و دیگه این ویجت بدردش نخوره این ویجت رو غیر فعال میکنه و از درخت حذف میکنه و در این مرحله متد زیر اجرا میشه :
deactivate

🔥در این مرحله هنوز متد dispose اجرا نمیشه و فقط deactivate اجرا میشه.

6⃣activate
اگه به این ویجت یه GlobalKey داده باشیم بعد از deactivate شدن ممکنه یه جای دیگه از درخت (با یه parent) دیگه به یه ویجت از این نوع و همین GlobalKey نیاز داشته باشه.
در نتیجه این ویجت activate میشه و توی اون نقطه از درخت مورد استفاده قرار میگیره و parent اش نسبت به قبل تغییر میکنه.(این اتفاق یعنی پیوند زدن به یه جای دیگه درخت حتمن باید توی همین فریم اتفاق بیفته که ویجت deactivate شده)
درنتیجه متد زیر توی state اجرا میشه :
activate
بعد از این متد هم متد
build
اجرا میشه و اگه این ویجت توی اجرای قبلی به یه inheritedWidget وابسته شده باشه قبل build هم متد زیر اجرا میشه :
didChangeDependencies
پس یا :
activate
build
یا
activate
didChangeDependencies
build
بسته به شرایط اجرا میشن.

7⃣unmount
اگه بعد از deactivate شدن و تا پایان این فریم این ویجت به هیچ جای دیگه پیوند نخوره (GlobalKey نداشته باشه یا لازم نشه که پیوند بخوره) متد زیر اجرا میشه :
dispose
و state برای همیشه میره پی کارش و غیر قابل استفاده میشه.

پس بلافاصله بعد از متد deactivate متد dispose اجرا نمیشه.
یه فاصله ای بینشون هست.
فاصله خیلی کم و در حد میلی ثانیه هست ولی بین اجرای این دو فاصله هست.

🔥همیشه قبل از dispose متد deactivate اجرا میشه ولی الزامن همیشه بعد از deactivate متد dispose اجرا نمیشه.

پس :
🔥توی initState هم به context دسترسی داریم.

🔥وابسته شدن به InheritedWidget رو حتمن توی didChangeDependencies یا build انجام میدیم.

🔥توی متد های deactivate و dispose کارهایی که مربوط به context میشه رو انجام نمیدیم (چون widget tree اون موقع statble نیست و در واقع این ویجت parent خودش رو از دست داده و parent نداره)

🔥کارهایی مثل dispose کردن کنترلر ها و ... رو توی متد dispose انجام میدیم و نه deactivate چون بعد از deactivate ممکنه دوباره به درخت برگرده و reperent بشه.

🔥در صورتی که ویجت GlobalKey داشته باشه (فقط GlobalKey) ممکنه بعد از deactivate شدن reparent بشه و به یه parent دیگه پیوند بخوره و مجددن activate بشه(که در این صورت state حفظ میشه)

#state_life_cycle
تو یه ساعت 1000 تا اهنگ رو با دارت از سطح وب خزش نمودم! 😎
عمرا گوگل هدفش از ساخت دارت این بوده باشه! 🤣
برای خوندن مقاله های پرمیوم سایت Medium میتونید از این اکستنشن استفاده کنید!

https://chrome.google.com/webstore/detail/read-medium-for-free/feckflmdfioohghkgojnilnlaelfgffl/related?hl=en
👍4
اگه گفتین Scrollable.ensureVisible

به چه دردی میخوره؟
👍4
Pushy

Lightning-fast, highly-reliable
push notification delivery

یه جایگزین برای پوش نوتیفیکیشن فایربیس؟

https://pushy.me
https://pub.dev/packages/pushy_flutter
https://pushy.me/docs/additional-platforms/flutter
👍5👎3
اگه می‌خواین Bottom navigation bar زمانی که کاربر اسکرول می‌کنه تو لیست ویو با یه انیمیشنی مخفی بشه یه نگاهی به این gist بندازید!


https://gist.github.com/H3mnz/04a1cf269b25c433ae07c19ff7d7f110
👍4
Muxa

این موزیک پلیر هم یکی از بچه ها با فلاتر نوشتن! 😍
نصب کنید و حالشو ببرید! 🤟

https://play.google.com/store/apps/details?id=com.matt.muxa
👍5
👍2
Simple Flutter TopSheet
اینم شاید به درد بخوره!
یه bottomSheet که از بالا باز میشه!!!!

https://gist.github.com/H3mnz/e50673ad5750f2dbff4fa99af5711042
👍3
Flutter Zone | فلاتر و دارت
Flutter Festivals are coming! https://events.withgoogle.com/flutter-festivals/
اخه کدوم شرکتی میاد برای فریمورک یا زبان برنامه نویسیش تو کل دنیا فستیوال بزاره!
بعد میگن فلاتر اینده نداره! 😐
👍11
‏کاش روحیه آدما تو انجام دادن کارا، مثل جامعه برنامه‌نویسی بود.
هر کی در حد توان یه گوشه کار رو میگیره.

یکی پکیج می‌ذاره تو گیت‌هاب
یکی سوال تو استک‌اورفلو جواب میده
یکی نمونه کد می‌ذاره تو codepen بقیه استفاده میکنن و ... و جالب اینه که اغلب به طور مستقیم آورده مالی نداره اینا

@DevTwitter | <مهیب/>
👍14