Flutter | فلاتر
2.57K subscribers
207 photos
34 videos
32 files
575 links
لینک گروه برای اشتراک منابع و یادگیری فلاتر
https://t.me/joinchat/EOllGEqgbASbAHtD03cXTA
حمایت از کانال:
idpay.ir/fluttery

انتقاد ،پیشنهاد،نوشتن مطلب:
@h_noroozi_t_96
@ni30000
Download Telegram
در برنامه نویسی در چه سطحی هستین (بدون ذکر زبان خاص)
Anonymous Poll
23%
حرفه ای
52%
متوسط
22%
نیاز به تمرین بیشتر
4%
اصلا برنامه‌نویس نیستم (مشاهده نتایج)
اگر به شما پیشنهاد کار گروهی در شرکت برنامه نویسی شود(توانایی ایجاد کامپوننت های جدید ، کار با بیشتر استیت منیجمنت ها، کد کلین،توانایی پیاده سازی دیزان پترن های مختلف،توانایی مچ شدن با تیم )
Anonymous Poll
28%
از پس کار برمیام
37%
بلدم ولی حین کار هم کمک میگیرم
26%
فعلا نمیتونم و نیاز به تمرین دارم
9%
مشاهده نتایج
سلام و عرض ادب
در صورت تمایل به همکاری با شرکت هوشمندنگار در بخش front & Flutter
به صورت حضوری و تمام وقت با توانمندی های زیر:

▫️ آشنایی با معماری اینترنت اشیا
▫️ مسلط به Flutter
▫️ آشنایی با HTML و CSS
▫️ توانمندی کار با پایگاه داده
▫️ آشنایی با API
▫️ دارای روحیه کار تیمی
▫️ توانایی مستندسازی پروژه ها
لطفا رزومه خودتون رو برام ارسال کنید تا جلسه مصاحبه براتون تنظیم بشه.
تهران میدان فردوسی
با سپاس
شماره واتساپ 09192258658
سلام خدمت همه عزیزان

دوستان کسی با لاراول میتونه یسری api هارو اماده کنه ؟!

برای دوره سایت اموزشی فروشگاهی با فلاتر وب میخثام این api ها استفاده بشه

@h_noroozi_t_96
خسته نباشید بچه ها ، آمار گیری تموم شده و نتایج رو میتونید خودتون مشاهده کنید
به صورت میانگین جامعه آماری این کانال نشون میده که دانش برنامه‌نویسی افراد در سطح متوسط رو به بالا هستن(البته یکسری از افراد اصلا نمی‌دونستن برنامه نویسی چیه و تویه کانال عضو هم هستن که جالب بود به نظرم)

البته بعضی از آمار ها با هم مطابقت نداشت(درآمد و شغل ) در هر صورت تشکر از همکاری تون و این که امیدوارم مفید بوده باشه براتون
از این به بعد یکسری کوییز و سوال در کانال میزاریم تا سطح واقعی خودتون رو بسنجین
سوالات و کوییز ها در سه سطح
مقدماتی ، متوسط ، پیشرفته
در کانال قرار میگیرن و فقط مختص یک زبان و فریمورک خاص نیستن
#نتیجه آمار
#کوییز
خودتون رو زیاد درگیر آموزش نکنید

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

هر چی بخونید و اموزش ببینید در نهایت میبینید اااا من این رو بلد نبودم پس هنوز ضعیف هستم نه این طور نیست شما نمیتونید صفر تا n دارت یا فلاتر رو حفظ باشید (هرکسی ادعا داره که این طور هستش به من پیام بده @MWDeveloper) شما باید وارد پروژه ها بشید به عنوان کاراموزی، جونیور، سنیور وارد پروژه ها بشید چون فقط و فقط توی پروژه میتونید چیز های زیادی رو یاد بگیرید و بر روی اون یاد گیری قبلی تسلط پیدا کنید


اگر بیشتر از سه ماه هستش دارید فیلم میبینید و فلاتر رو دارید یاد میگیرید برید دنبال کار آموزی و استخدام جونیوری و وارد گروزه های بزرگ و چالش های بزرگ بشید

در نهایت در کنارشون ساعتی اختصاص بدید به اموزش و یاد گیری 🌹
Forwarded from Pure Coder
⚡️⚡️اطلاعات عمومی⚡️⚡️

فلاتر از سه قسمت تشکیل شده
Framework
Engine
Embedder

اون قسمتی که ما برنامه نویس های فلاتر باهاش کار میکنیم Framework هست و کلن با زبان dart نوشته شده.

اما Engine با c++ نوشته شده.

قسمت Framework و Engine به وسیله یه کتابخونه به اسم dart:ui با هم ارتباط برقرار میکنن و این کتابخونه رابط بین این دو قسمت هست.

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

هر لایه فقط میتونه به لایه زیری دسترسی داشته باشه.
مثلن لایه Rendering فقط به 4 لایه زیر خودش دسترسی داره.
مقدار خروجی بالا چیست
Anonymous Poll
15%
false
47%
true
6%
2
9%
Error
23%
مشاهده جواب
پدرام و پدرش روی هم رفته دو سیب دارند ، زاویه دست پدرام تا سیب تانژانت 45 رادیان می باشد
اکنون با توجه به شکل بالا و اطلاعات داده شده سن پدرام رو پیدا کنید؟
نکته زاویه بر اساس رادیان(rad)می باشد.
Anonymous Quiz
7%
0
12%
رندوم و نامشخص
24%
24
18%
error
6%
22
33%
مشاهده نتایج
در شکل بالا یک ایراد کوچک وجود دارد با رفع ایراد به نظر شما جواب نهایی چه خواهد بود
Anonymous Quiz
16%
true
21%
shabaNumber is wrong
12%
21
18%
shabaNumber is Curect
4%
ERROR
29%
مشاهده نتایج
تجربه ناخوش‌آیند بکی از دوستان در رابطه با اهمیت گیت

خواهشن با گیت کار کنید
من دو روزه حالم بده
یه اپلیکیشن آب و هوا و راه نوشته بودم که توی اپلیکیشنم یه امکان گذاشته بودم که شما مسیرتو انتخاب میکردی (مثلا از تهران به رشت) و ده دقیقه قبل از هر ایونتی بهش آلارم میداد
مثلا قراره بارون بیاد یا تا چند دقیقه دیگه باران تمام میشود و تا فلان جا دیگه هوا بارانی نیست و از اینجور چیزا
هارد لپ تاپم سوخت
دو روزه از بس اعصابم بهم ریخته است که حتی توان شروع دوباره ندارم
اگر یه ریپازیتوری توی گیت داشتم هیچوقت کل پروژه به فنا نمیرفت
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 حفظ میشه)

#statefulwidget
#state_life_cycle
#فلاتر
#آسان
#کوییز
در کد نوشته شده یک مشکل وجود دارد که با تصحیح آن میتوانیم شکل سمت راست را ببینیم
اشتباه کد در کجاست ؟(جواب درست رو کامنت کنید)