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
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 تا اهنگ رو با دارت از سطح وب خزش نمودم! 😎
عمرا گوگل هدفش از ساخت دارت این بوده باشه! 🤣
عمرا گوگل هدفش از ساخت دارت این بوده باشه! 🤣
فلاتر 2.10.0 و دارت 2.16.0 رسید! 😍
بزنید برا آپگرید!
لینک Window Update
https://www.youtube.com/watch?v=g-0B_Vfc9qM
بزنید برا آپگرید!
لینک Window Update
https://www.youtube.com/watch?v=g-0B_Vfc9qM
YouTube
Flutter Update: Windows
Announcing Flutter support for Windows!
With Flutter 2.10, you can now build Windows apps using Flutter. With a single codebase, you can build high-quality Windows apps that also run on mobile and web.
Read the blog → https://goo.gle/3HpR3cS
Flutter…
With Flutter 2.10, you can now build Windows apps using Flutter. With a single codebase, you can build high-quality Windows apps that also run on mobile and web.
Read the blog → https://goo.gle/3HpR3cS
Flutter…
Announcing Flutter for Windows
https://medium.com/flutter/announcing-flutter-for-windows-6979d0d01fed
https://medium.com/flutter/announcing-flutter-for-windows-6979d0d01fed
Dart 2.16: Improved tooling and platform handling
https://medium.com/dartlang/dart-2-16-improved-tooling-and-platform-handling-dd87abd6bad1
https://medium.com/dartlang/dart-2-16-improved-tooling-and-platform-handling-dd87abd6bad1
Medium
Dart 2.16: Improved tooling and platform handling
Supporting Flutter for Windows with package platform tagging and a new search experience for pub.dev
❤1👍1
👍2
Flutter 2.10.0 release notes
لیست رفع باگ های فلاتر 2.10
https://docs.flutter.dev/development/tools/sdk/release-notes/release-notes-2.10.0
لیست رفع باگ های فلاتر 2.10
https://docs.flutter.dev/development/tools/sdk/release-notes/release-notes-2.10.0
docs.flutter.dev
Flutter 2.10.0 release notes
Release notes for Flutter 2.10.0.
👍2
برای خوندن مقاله های پرمیوم سایت Medium میتونید از این اکستنشن استفاده کنید!
https://chrome.google.com/webstore/detail/read-medium-for-free/feckflmdfioohghkgojnilnlaelfgffl/related?hl=en
https://chrome.google.com/webstore/detail/read-medium-for-free/feckflmdfioohghkgojnilnlaelfgffl/related?hl=en
👍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
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
https://gist.github.com/H3mnz/04a1cf269b25c433ae07c19ff7d7f110
Gist
Hiding and Showing BottomNavidationBar in Flutter Scrollable Widgets
Hiding and Showing BottomNavidationBar in Flutter Scrollable Widgets - toggle_bottom_navigation_bar.dart
👍4
Muxa
این موزیک پلیر هم یکی از بچه ها با فلاتر نوشتن! 😍
نصب کنید و حالشو ببرید! 🤟
https://play.google.com/store/apps/details?id=com.matt.muxa
این موزیک پلیر هم یکی از بچه ها با فلاتر نوشتن! 😍
نصب کنید و حالشو ببرید! 🤟
https://play.google.com/store/apps/details?id=com.matt.muxa
👍5
Simple Flutter TopSheet
اینم شاید به درد بخوره!
یه bottomSheet که از بالا باز میشه!!!!
https://gist.github.com/H3mnz/e50673ad5750f2dbff4fa99af5711042
اینم شاید به درد بخوره!
یه bottomSheet که از بالا باز میشه!!!!
https://gist.github.com/H3mnz/e50673ad5750f2dbff4fa99af5711042
Gist
Simple Flutter TopSheet
Simple Flutter TopSheet. GitHub Gist: instantly share code, notes, and snippets.
👍3
Flutter Zone | فلاتر و دارت
Flutter Festivals are coming! https://events.withgoogle.com/flutter-festivals/
اخه کدوم شرکتی میاد برای فریمورک یا زبان برنامه نویسیش تو کل دنیا فستیوال بزاره!
بعد میگن فلاتر اینده نداره! 😐
بعد میگن فلاتر اینده نداره! 😐
👍11
Forwarded from DevTwitter | توییت برنامه نویسی
کاش روحیه آدما تو انجام دادن کارا، مثل جامعه برنامهنویسی بود.
هر کی در حد توان یه گوشه کار رو میگیره.
یکی پکیج میذاره تو گیتهاب
یکی سوال تو استکاورفلو جواب میده
یکی نمونه کد میذاره تو codepen بقیه استفاده میکنن و ... و جالب اینه که اغلب به طور مستقیم آورده مالی نداره اینا
@DevTwitter | <مهیب/>
هر کی در حد توان یه گوشه کار رو میگیره.
یکی پکیج میذاره تو گیتهاب
یکی سوال تو استکاورفلو جواب میده
یکی نمونه کد میذاره تو codepen بقیه استفاده میکنن و ... و جالب اینه که اغلب به طور مستقیم آورده مالی نداره اینا
@DevTwitter | <مهیب/>
👍14