آموزش RxJS برنامهنویسی ریاکتیو در جاوااسکریپت!

آموزش جامع و پیشرفته کتابخانه RxJS دانشجویار

این کتابخونه جاوااسکریپتی توسط گروهی از برنامه‌نویس‌های با تجربه و به‌روز طراحی شد که می‌خواستن مدیریت جریان‌های داده توی جاوااسکریپت رو به یه سطح کاملاً جدید ببرن. با استفاده از RxJS، برنامه‌نویس‌ها حالا می‌تونستن به راحتی با جریان‌های داده که مرتب به‌روزرسانی می‌شن، کار کنن؛ به این معنی که دیگه نیازی نبود برای هر تغییر جدید به صورت دستی کدهای پیچیده بنویسن. RxJS به سرعت محبوب شد، مخصوصاً بین برنامه‌نویس‌هایی که به ساخت اپلیکیشن‌های بلادرنگ و پیچیده علاقه داشتن، و تبدیل به ابزاری ضروری برای توسعه‌ی نرم‌افزارهای تحت وب مدرن شد. برای یادگیری Es6 شما نیاز دارید که به جاوا اسکریپت (javascript) مسلط باشید.لازم نیست که برای این مساله نگرانی داشته باشید،میتونید از دوره آموزش رایگان جاوا اسکریپت (javascript)  به صورت کاملا رایگان استفاده کنید. البته اگر علاقه مند به یادگیری تخصصی تر و پروژه محور جاوا اسکریپت هم بودید میتونید نگاهی به دوره جامع و پیشرفته جاوا اسکریپت بندازید.

با وجود فریمورک هایی مثل React native و Electron حتی اپلیکیشن های اندروید، ویندوز و ios خودتون رو فقط با جاوا اسکریپت بنویسید و گسترش بدید. همون‌طور که گفتیم RxJS یه کتابخونه قدرتمند و کارآمد برای مدیریت جریان‌های داده‌های پیچیده و رویدادهای لحظه‌ای در جاوااسکریپته. این ابزار با امکانات ویژه‌ای که داره، به برنامه‌نویس‌ها این امکان رو می‌ده که اپلیکیشن‌هایی بسازن که بدون تأخیر و با کمترین خطا به تغییرات و داده‌های جدید واکنش نشون بدن. اگر پروژه‌ای داری که در اون داده‌ها نیاز به به‌روزرسانی‌های مکرر دارن، RxJS می‌تونه انتخاب ایده‌آلی باشه. ببینید دوستان، اینکه چقد زمان لازمه تا جاوااسکریپت یادبگیرید همش به خودتون بر میگرده.

برای کمک به سایت ما و گسترش آموزش در بین هموطنان، در سایتها، وبلاگ ها و شبکه های اجتماعی لینک سایت ما را درج کنید. کاربرد گسترده این زبان در سایت‌ها و صفحات اینترنتی بوده و به کمک این زبان می‌توان به اشیاء داخل صفحات HTML دسترسی پیدا کرد و آن‌ها را تغییر داد. فقط کافیه دستور npm install rxjs رو اجرا کنی و بعدش توی پروژه ازش استفاده کنی. در این مثال از رویداد اسکرول به عنوان Observable استفاده کردیم و با throttle Time کاری می‌کنیم که هر ۵۰۰ میلی‌ثانیه فقط یک بار رویداد بررسی بشه و filter به RxJS می‌گه که فقط وقتی به انتهای صفحه رسیدیم، پیام نمایش داده بشه. همچنین، هدف در اینجا پوشش دادن تک تک اپراتورها نیست، بلکه در عوض، یک زیرمجموعه توسعه یافته را انتخاب می‌کنیم که متداول‌ترین عملگرهای مورد استفاده را شامل می‌شود و مثال‌های عملی برای هر کدام ارائه می‌شود.

وی که هم اکنون (2016) ۶۰ سال سن دارد در ۱۹۹۵ سایتی را راه اندازی کرد که به عنوان منبعی رایگان برای دانش آموزان محسوب می شد. طی آن دوران لیندا به صورت خودآموز در حال یادگیری طراحی وب بود و تلاش داشت تا آموخته هایش را با سایرین نیز به اشتراک بگذارد. هر چند این روزها مسئله یاد شده امری عادی به حساب می آید اما در اواسط دهه نود -روزگاری که هنوز یوتیوبی نبود- یادگیری طراحی وب به صورت خودجوش چندان مسئله رایجی محسوب نمی گشت. برای اجرا کردن دستورات جاوا اسکریپت در سایت نیاز به بارگذاری جاوا اسکریپت روی قالب سایت داریم. شروع هرچیزی سخته، ولی وقتی مسیر درستی رو انتخاب کنی،
با خیال راحت و بدون استرس میتونی از مسیر لذت ببری. ما در سبزلرن، توی سفر به دنیای برنامه نویسی کنارت هستیم تا باهم رشد کنیم و از نتیجه زحمات مون لذت ببریم.

اگه پروژه‌ای داری که نیازمند به‌روزرسانی لحظه‌ای اطلاعاته، RxJS می‌تونه کارتو راحت کنه و کد رو مرتب‌تر و قابل مدیریت‌تر کنه. فرض کن توی یه بازی ویدیویی داری کاراکتر بازی رو کنترل می‌کنی؛ می‌پره، شلیک می‌کنه، یا از یه مانع رد می‌شه. اینجا RxJS مثل یه مربی حرفه‌ای عمل می‌کنه و جریان هر حرکت رو زیر نظر می‌گیره. هر بار که بازیکن یه کاری انجام می‌ده، RxJS اون حرکت رو به سرعت پردازش می‌کنه و واکنش مناسب نشون می‌ده. به کمک RxJS، حرکات بازیکن سریع‌تر و بدون تاخیر انجام می‌شن و بازی یه تجربه روان و هماهنگ به بازیکن می‌ده.

پس اگه دوست دارید بهترین آموزش جاوا اسکریپت رو به صورت صفر تا صد دریافت کنید، میتونید روی سبزلرن حساب کنید. اما با گذشت زمان اونقدر توسعه داده شد که میشه گفت آچار فرانسه دنیای برنامه نویسی شده و در همه زمینه ها از طراحی وب گرفته تا سیستم های رزرواسیون و اینترنت اشیاء کاربرد داره. در کنار RxJS، کتابخانه‌های مشابهی مثل Bacon.js، Most.js، Kefir.js و Highland.js هم هستن که هر کدوم ویژگی‌های مخصوص به خودشون رو دارن. مثلاً Most.js برای پروژه‌های سنگین با نیاز به سرعت بالا، و Bacon.js برای مدیریت رویدادهای ساده و سریع مناسبه. انتخاب درست هر کدوم از این کتابخونه‌ها می‌تونه توی کارایی و سادگی پروژه خیلی تأثیر داشته باشه. RxJS یه کتابخونه برای جاوااسکریپته که بهت کمک می‌کنه جریان‌های داده‌های پیچیده رو مدیریت کنی.

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

آموزش شروع به کار با RxJS یکی دیگر از آموزش های گروه آموزشی پرووید می باشد که در این قسمت آن را به شما معرفی می کنیم. عنوان این بسته آموزشی، یادگیری کتابخانه RxJS است که با نام اصلی RxJS 6 – Getting Started از شرکت Pluralsight منتشر شده است. آموزش جاوا اسکریپت دوره ای است که در قالب آن ما تمامی مفاهیم پایه و اساسی javascript رو به همراه مثال هایی واقعی به شما آموزش می دهیم. وقتی می‌گیم Observable، یعنی چیزی که می‌تونه اطلاعات رو تولید و منتشر کنه. برای مثال، فرض کن تو یه اپلیکیشن داری و کاربر داره روی دکمه‌ها کلیک می‌کنه. هر بار که کاربر روی یه دکمه کلیک می‌کنه، یه اطلاعات جدید ایجاد می‌شه که این رو می‌تونی با Observable ثبت کنی.

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

برای پروژه‌های ساده و سبک، شاید ابزارهای دیگه‌ای مثل Bacon.js یا Kefir.js گزینه‌های بهتری باشن. در این مثال با fromEvent یه جریان برای رویدادهای ورودی کاربر می‌سازیم و debounceTime کاری می‌کنه که فقط وقتی کاربر تایپ رو متوقف کرد، مقدار ورودی ارسال بشه. از map استفاده می‌کنیم تا فقط مقدار ورودی رو دریافت کنیم و اون رو پردازش کنیم. فرض کن می‌خوای وقتی کاربر توی یه فرم شروع به تایپ کردن می‌کنه، بعد از تموم شدن تایپش اطلاعات پردازش بشه و نه هر بار که یه کلید رو فشار می‌ده. فکر کن یه صفحه وب طراحی کردی که توش وقتی کاربر اسکرول می‌کنه، تصاویر پس‌زمینه با حرکت اسکرول کاربر جابه‌جا می‌شن و یه افکت پارالاکس (حرکت همزمان و با عمق) ایجاد می‌کنن. RxJS اینجا کاری می‌کنه که جریان اسکرول به دست بیاد و بتونی به تصاویر دستور بدی که دقیقاً همگام با اسکرول حرکت کنن.

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

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

بیایید نگاهی بندازیم به جنبه‌های مثبت و منفی RxJS تا ببینیم چرا برنامه‌نویس‌ها عاشقشن و در عین حال کجاها ممکنه چالش‌برانگیز بشه. لیندا دات کام قالبی معین و کارآمد را برای دوره های آموزشی اش پدید آورده و سپس کوشش کرده تا از نظر موضوعی نیز در بین مطالب مورد تدریس خود تنوع ایجاد نماید. روزگاری در وب سایت مورد بحث تنها ۲۰ دوره آموزش ویدئویی آنلاین وجود داشت، اما اکنون این رقم به ۶۳۰۰ رسیده که شامل ۲۶۷.۰۰۰ ویدئوی آموزشی می گردد. کسب و کار لیندا پس از چند سال توانست ۳۵ فرصت شغلی را ایجاد و درآمدی ۳.۵ میلیون دلاری را فراهم کند. اما در سال ۲۰۰۱ و پس از انفجار حباب دات کام و حوادث مرتبط به یازده سپتامبر، تمایل افراد به یادگیری دروس طراحی وب کاهشی عجیب پیدا کرد، تا جایی که واینمن و همسرش در ادامه دادن مسیر مردد شده بودند.

این جامع بودن دوره مزیت دیگری دارد و آن نیز راحت شدن شما از کلاس‌های غیر پیوسته است. این دوره به دلیل جامع بودن، به شما کمک می‌کند تا یادگیری به طور کامل انجام شود و شما به طور کامل و جامع و بدون گسستگی این دوره را بگذرانید و نیاز به دوره دیگری برای آموزش کتابخانه RxJS نداشته باشید. همه ما از توانایی های فوق العاده جاوااسکریپت با خبر هستیم ، اما نسخه ۲۰۱۵ EcmScript یا به اصطلاح همون ES6 (اکما اسکریپت 2015) تغییراتی در خودش داشت که مجبوبیت جاوااسکریپت رو چندین برابر کرد . EcmaScript 2015 یا همون ES6 قابلیت های بسیاری دارد که در تمامی کتابخانه ها و فریمورک های جاوا اسکریپت مثل react,vue,angular,react native,svelte,electron ,… مورد استفاده قرار می گیرد. با اعداد، رشته ها و آرایه ها در جلسات قبل به طور کامل آشنا شدیم و این جلسه نوبتی هم باشه، نوبت Objectها یا اشیاس. Objectها یکی از انواع داده ای است که در جاوا اسکریپت به شدت کاربردیه و در اکثر مواقع استفاده میشه.

یک زبان مشهور و محبوب که با جامعه‌ای فعال و بزرگ، یکی از کامل ترین و رایج ترین زبان های برنامه نویسی دنیاست. بعد از پیشرفت باور نکردنی جاوا اسکریپت در سمت کلاینت، نوبت به حضور جاوا اسکریپت در سمت سرور حس میشد. که در سال 2009 بعد از معرفی پلتفرم Nodejs جاوا اسکریپت به زبان برنامه نویسی کاملی تبدیل شد. شما با یادگیری Nodejs و فریمورک Express JS میتونید اپلیکیشن ها و وبسایت های خودتون رو در سمت سرور هم توسعه بدید و برنامه نویس Back-end بشید. در ادامه آموزش های کاربردی برنامه نویسی جاوا اسکریپت، بعد از حدود ۱ هفته گشت و گذار در اینترنت و از بین هزاران ویدیو، یک مجموعه بی نقص و کامل ویدیویی را برای یادگیری سریع این زبان برنامه نویسی گلچین کرده ایم. بعد از آن نیز بهترین جزوه PDF فارسی موجود در اینترنت را جهت تکمیل یادگیری می توانید دانلود کنید.

جاوا اسکریپت یک زبان برنامه نویسی همه فن حریف برای برنامه نویسی وبسایت، اپلیکیشن، هوش مصنوعی، ربات تلگرام، فیلترنویسی اینستاگرام و حتی بازی سازی استفاده میشه. وبسایت MEGAJS اولین مرجع تخصصی آموزش جاوااسکریپت، کتابخونه ها و فریمورک های JavaScript به زبان فارسی هست. میانگین حقوق توسعه دهنده جاوا اسکریپت در ایران (در سال ۹۸) ماهانه ۳ تا ۸ میلیون تومان است. شما میتونید با یادگیری جاوا اسکریپت به عنوان برنامه نویس Frond-end یا Back-end یا برنامه نویس Full stack JS (یعنی کسی که هم Front end بلده هم Back end) مشغول کار بشید. شما میتونید با یادگیری جاوااسکریپت کدهای سرور ساید خودتون رو بنویسید و وبسایت و اپلیکیشن خودتون رو تنها با یادگیری جاوا اسکریپت در سمت سرور توسعه بدید.

برای همین اگه بخوای بدون ابزار خاصی این کار رو انجام بدی، برنامت تبدیل می‌شه به یه کد شلوغ و پیچیده که مدام هم احتمال خطا توش هست. با گذراندن این دوره یاد خواهید گرفت که چگونه از کتابخانه RxJs در عمل برای ساخت برنامه های کاربردی در سبک واکنشی استفاده کنید. مفاهیم اصلی را که اساس برنامه نویسی واکنشی هستند، مانند Streams و Observables به خوبی درک خواهید کرد. رشته ها یا Strings یکی از انواع داده ای بود که در روز ششم از تونل یادگیری جاوا اسکریپت راجع به آن صحبت کردیم. رشته ها در واقع همون کلمه یا Text محسوب مشن و برای اینکه جاوا اسکریپت متوجه این قضیه بشه که داده ما از نوع رشته یا کلمه است باید از ۲تا کوتیشن یا دبل کوتیشن استفاده کنیم و داخل آن متن مورد نظرو بنویسیم. قبلا که آگاهی دانشجوها کم بود اول به ما زبان برنامه نویسی یاد میدادن بعد حالا باید می گشتیم کاربردش رو پیدا کنیم.

این مزیت ها در شرایطی که به‌روزرسانی‌های زمان‌واقعی، تعاملات کاربری و همگام‌سازی داده ها مهم هستند اثرگذارتر می شوند. با کتابخانه RxJS، توسعه‌دهندگان می‌توانند یک معماری state management قابل نگهداری و ماژولار ایجاد کنند، که این خود کمک می کند تا پیچیدگی مرتبط با مدیریت رویدادهای ناهمگام کاهش یافته و استحکام کلی برنامه را افزایش پیدا کند. تا وقتی لاراول هست کی میره سراغ بک اند با نود جی اس یا تا وقتی اندروید هست کی میره ری اکت نیتیو و…! اما امروز میتونید ببینید تقریبا اتفاق نظر دارن کل بچه های برنامه نویس جهان که جاوااسکریپت به ابر زبان برنامه نویسی تبدیل شده و امروزه نمیتونید حوزه ای رو بگید که با جاوااسکریپت نتونی باهاش کار کنی. دوره آموزش جاوا اسکریپت مربوط به زبان برنامه نویسی جاوا اسکریپت (Javascript) هست.

Bacon.js یکی از کتابخانه‌های محبوب برای مدیریت جریان‌های داده و رویدادهاست. این کتابخانه امکانات مشابهی با RxJS داره اما بیشتر تمرکزش روی کارهای تعاملیه، مثل مدیریت رویدادهای فرم و عناصر رابط کاربری. اگر نیاز داری که فقط روی جریان‌های داده ساده و رویدادهای مرورگر کار کنی، Bacon.js می‌تونه انتخاب مناسبی باشه و سبک‌تر از RxJS هم هست. اگر به دنبال جایگزینی برای RxJS هستی یا می‌خوای گزینه‌های دیگه رو برای مدیریت جریان داده‌ها در پروژه‌های مختلفت بررسی کنی، چندین کتابخانه‌ی محبوب و کاربردی وجود دارن که هر کدوم مزایای خودشون رو دارن. در ادامه، به معرفی چند مورد از بهترین ابزارهای مشابه RxJS می‌پردازیم و بهت نشون می‌دیم که چه قابلیت‌هایی دارن و برای چه پروژه‌هایی مناسب هستن.

کتابخانه RxJS از مفهوم Observable ها برای مدیریت رویدادها و داده‌های غیرهمزمان استفاده می‌کند و قابلیت ترکیب، فیلتر کردن و پردازش این جریان‌ها را به‌صورت بسیار انعطاف‌پذیر فراهم می‌آورد. این کتابخانه با استفاده از Operator ها مختلف به توسعه‌دهندگان کمک می‌کند تا جریان داده‌ها را دستکاری کرده و به روش‌های مختلف آن‌ها را مدیریت کنند. کتابخانه RxJS به‌ویژه در برنامه‌های جاوااسکریپت و فرانت‌اند وب مانند Angular کاربرد فراوانی دارد. جاوا اسکریپت یک زبان برنامه نویسی پرکاربرد و پراستفاده در دنیاست که هر روزه در حال پیشرفت و تکامل هست و کتابخانه ها و فریمورک های زیادی با این زبان نوشته شدند. زبان برنامه نویسی جاوا اسکریپت یک زبان مفسری هست که امروز در بیشتر زمینه ها از این زبان محبوب و جذاب استفاده می شود.

متوسط درآمد یک برنامه نویس جاوا اسکریپت در آمریکا سالیانه 79 هزار دلار هست که نشان از درآمد بالای برنامه نویسان جاوا اسکریپت در دنیا داره. RxJS برای مدیریت بهینه جریان‌های داده طراحی شده، اما اگه به درستی ازش استفاده نشه یا توی پروژه‌هایی که نیاز به پیچیدگی ندارن استفاده بشه، می‌تونه سنگین بشه و عملکرد رو کاهش بده. با این توضیحات دیدیم که RxJS چطور می‌تونه توی دنیای انیمیشن‌ها و بازی‌ها هم حسابی به‌کار بیاد. اما شاید برات سوال بشه که چطور می‌تونی همین حالا RxJS رو توی پروژه‌هات استفاده کنی و جریان‌های داده رو به سبک حرفه‌ای‌ها کنترل کنی؟پس بیا با هم چندتا مثال همراه کد ببینیم. بانی برنان یک معمار Angular و بنیانگذار ngHouston Angular Meetup است.او همراه دختر نوجوانش همچنین Code Bridge Texas را تاسیس کرد، که در آن ، آنها کارگاه‌های برنامه‌نویسی رایگان برای دختران و زنان را برنامه‌ریزی می‌کنند. بانی از سال 2013 در نوشتن و تدریس Angular مشغول است و از کیفیت کد، آموزش مداوم و توانایی دیگران که می خواهند یاد بگیرند، لذت میبرد.

در این دوره سعی کردیم از پایه ترین و اساسی ترین مفاهیم شروع  و به صورت گام به گام مفاهیم پیشرفته تر رو بیان کنیم. ذخیره نام، ایمیل و وبسایت من در مرورگر برای زمانی که دوباره دیدگاهی می‌نویسم. ما همچنین مفهوم موضوع را پوشش خواهیم داد و مثال هایی از چندین موضوع پرکاربرد مانند BehaviorSubject یا AsyncSubject ارائه خواهیم داد. اگر توسعه‌دهنده‌ای هستید که به تازگی با اکوسیستم Angular شروع کرده‌اید، یا حتی اگر قبلاً تجربه‌ای با آن دارید، سخت‌ترین قسمت آن RxJs است. در حالکیه لیندا اعتقاد دارد تنها در زمان و مکان مناسبی حضور داشته، سخت است بدل شدن یک دامنه ی ۳۵ دلاری به کسب و کاری ۱.۵ میلیارد دلاری را حاصل یک اتفاق بدانیم.


برنامه نویسی ربات تلگرام