آترین عباسیان
آترین عباسیان
خواندن ۷ دقیقه·۳ سال پیش

ری اکت چیست و چرا اینقدر محبوب است؟

ری اکت (React js) نامی که این روز ها در دنیای برنامه نویسی وب زیاد به گوش می خورد. در این مقاله قصد داریم تا درباره ی React که یکی از پرطرفدار ترین کتابخانه های جاوااسکریپت هست مطالبی را بیان کنیم و ویژگی های React js را زیر ذره بین ببریم.




ری اکت ( REACT ) چیست؟

ری اکت یکی از کتابخانه های جاوااسکریپت در طراحی رابط کاربری (User Interface) است که در سال 2011 توسط کمپانی بزرگ فیسبوک توسعه داده شد. ری اکت در صفحات وب هر بخش از صفحه یا در اصطلاح هر (Component) را پس از اعمال تغییر دوباره رندر گرفته و به نمایش در می آورد. ری اکت در رندر سریع و مجدد هر بخش از صفحه با استفاده از (Virtual DOM) به صورت مستقل و هم چنین در طراحی UI کاربرد بسیار زیادی دارد.

جردن واک یکی از مهندسین نرم افزار شرکت فیس‌بوک این کتابخانه را ایجاد کرد که در سال 2011 برای ویژگی Newsfeed مورد استفاده قرار گرفت. برای اولین بار React js بر روی خبرنامه فیس بوک در سال 2011 و بر روی Instagram در سال 2012 پیاده سازی شد. همچنین کتابخانه React js این اجازه را می دهد تا بتوانیم کامپوننت هایی با قابلیت استفاده مجدد نیز طراحی و ایجاد کنیم.




ویژگی‌ها و کاربردهای ری اکت

ری اکت این قابلیت را برای برنامه نویسان فراهم می کند تا برنامه های کاربردی تحت وبی را طراحی کنند که بدون بارگزاری مجدد صفحه می توان اطلاعات آن را تغییر داد. ما می توانیم عناصر رابط کاربری مانند یک دکمه یا یک ورودی فرم را به عنوان یک کامپوننت ری اکت بنویسیم. یک کامپوننت ممکن است یک یا چند کامپوننت دیگر را در خروجی خود داشته باشد.

حال بریم سراغ ویژگی های ری اکت :

1. ساده بودن یادگیری : درک مفاهیم React بسیار ساده است و شاید مهم ترین عامل برای روی آوردن به این کتابخانه همین مسئله است. ری اکت مانند انگولار پیچیده نیست و اگر تنها به جاوااسکریپت مسلط باشید، یادگیری ری اکت برای شما بسیار لذت بخش خواهد بود.


2. استفاده از JSX : ری اکت از یک syntax ویژه با نام JSX استفاده می‌کند که اجازه می‌دهد HTML و جاوا اسکریپت را ترکیب کنیم. به عبارت دیگر استفاده از JSX به این صورت است که ما در بین کد های HTML خود کد های جاوااسکریپت می نویسیم. استفاده از JSX در ریکت الزامی نیست ولی استفاده از آن باعث افزایش سرعت اجرا می شود و توصیه می شود که هنگام کار با React از JSX استفاده شود. استفاده از JSX اوایل ممکن است باعث سردرگمی شما شود اما پس از تمرین و استفاده ی مکرر، کدنویسی آن برایتان لذت بخش خواهد شد.

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


4. رویکرد Native : ساخت اپلیکیشن های موبایل تا چندی پیش توسط دو زبان برنامه نویسی جاوا برای اندروید و سوئیفت برای ios صورت می گرفت و اگر قصد ساخت و تولید برنامه برای کسب و کار خودمان را داشتیم، باید هر دو را به طور کامل فرا می گرفتیم. یادگیری جاوا و سوئیفت هم زمانبر و در مواردی هزینه بر هم می باشد. اما توسط زبان ها و فریم ورک های نیتیو می توانیم یک اپلیکیشن واحد را طراحی کنیم و دو خروجی اندروید و ios را همزمان از آن دریافت کنیم. ری اکت نیتیو  (React native) پس از انتشار زیاد مورد استقبال قرار نگرفت اما به مرور زمان و پس از اضافه شدن چندین ویژگی مختلف به آن، استقبال شدیدی از آن صورت گرفت و افراد زیادی به آن روی آوردند.



نحوه‌ی کار Hook‌ ها در React

هوک ها توابعی در React هستند که امکان استفاده از state و ویژگی‌ های React در یک کامپوننت مبتنی بر تابع را به ما می‌ دهند. Hook ها به ما این امکان را می‌دهند تا به جای جابجایی بین HOC ها، کلاس‌ها و توابع، از توابع استفاده کنیم. از آنجایی که Hook‌ ها توابع جاوااسکریپت معمولی هستند، می‌ توانیم از Hook‌ های پیش‌فرض استفاده کرده و هم چنین Hook دلخواه خودمان را ایجاد کنیم. بنابراین راه‌ حل مشکل ما اکنون یک دستور یک‌ خطی خواهد بود.


دو مورد از مهم ترین و پرکاربرد ترین هوک ها در ری اکت، useState و useEffect هستند.




نحوه‌ی کار React Router در React

ری اکت روتر کتابخانه (Package) ای است که به ما این امکان را می دهد تا route های خود را در front-end مشخص کنیم. بنابراین کاربران کامپوننت ها را در مسیرهایی مثل localhost:3000/home و … می بینند. ما می توانیم یک برنامه React ایجاد کنیم اما اینکه با کلیک کردن بر روی آیکون چه کامپوننتی نمایش داده شود یا به چه صفحه ای منتقل شود به ما مربوط است.


کامپوننت home برای روت / ، کامپوننت درباره‌ی ما برای روت about/ و کامپوننت تماس با ما برای روت contact/ می باشد.




نحوه‌ی کار Context API در React

روشی است برای قادر سازی کامپوننت‌ها برای به اشتراک گذاری داده‌ها بدون این که به صورت خارجی از هر کامپوننت به صورت دستی بگذریم. Context نسبت به زیر شاخه کامپوننت React، مانند یک آبجکت Global است.

نحوه پیاده سازی Context در React :

1. اولین قدم این است که با استفاده از متد create، یک Context‌ بسازیم. کامپوننت‌ ها در سطوح مختلف از Context مشابه برای دریافت داده‌ ها استفاده خواهند کرد.

2. مهیا کننده (Provider) یک کامپوننت است که Consumer‌ را قادر می‌سازد تا در تغییرات اعمال شده به Context شریک شوند. Provider یک prop به نام value می‌پذیرد و داده‌ های داخل این prop برای تمام Consumer های فرزند در دسترس هستند.

3. مصرف کننده (Consumer‌) یک دریافت کننده Context است. کامپوننت‌ ها می‌ توانند با جمع‌ بندی Consumer به دور Context، در مقادیر آن شریک شوند. Consumer به یک متد با یک پارامتر نیاز دارد که یک گره React را بر می‌ گرداند و آن را با برنامه می‌ سازد.




ریداکس ( Redux ) چیست؟

ریداکس یک الگو برای مدیریت بهتر و بهینه تر وضعیت های مختلف در برنامه را ارائه داده است. ریداکس در سال 2015 ارائه شده است و از این فریم ورک به عنوان مکمل در کنار فریم ورک های دیگر مثل همین React استفاده می کنند. به دلیل متن باز (Open Source) بودن این فریم ورک کد های آن در گیت هاب موجود است. استفاده از ریداکس یک راه سریع و کوتاه برای رسیدن به هدف نیست اما اگر پروژه ما دچار مشکل شد می توانیم از ریداکس استفاده کنیم. برای مدیریت حالات به کاربرده می شود و اگر نیاز به مدیریت states بود می توانیم از آن استفاده کنیم. در غیر این صورت استفاده از آن ضرورتی ندارد به دلیل اینکه کار را سخت و پیچیده می کند، که در این صورت می توانیم از همان Context API استفاده کنیم. ریداکس از چهار بخش تشکیل شده که با هم در ارتباط هستند و در کنار یکدیگر کار می کنند. این چهار بخش شامل موارد زیر می باشد:

1. بخش اول Store : مکانی می باشد که تمامی state ها یا داده های ما جدا از هر کامپوننتی ذخیره می شوند.

2. بخش دوم Reducer : تابعی است که کار آن انجام عملیات مختلف روی state می باشد.

3. بخش سوم Action : یک شیء (Object) می باشد که کار خاصی را انجام نمی دهد و فقط ارسال می شود به Reducer.

4. بخش چهارم Action : Dispatch را به سمت Reducer اعزام می کند.




آینده کتابخانه REACT

زبان جاوا اسکریپت و همه ی فریم ورک های آن در حال حاضر از جایگاه خیلی خوبی در دنیای بزرگ برنامه نویسی برخوردار هستند و رقابت بالایی را با هم دارند. کتابخانه React در رقابت با دو رقیب سر سخت خود یعنی انگولار و ویو رتبه ی اول را دارد. برنامه های بزرگی مانند Netflix ، Facebook ، Instagram و … از React native استفاده می کنند و برنامه نویسی اپلیکیشن های اندروید و ios نیز رویکرد فعالی در استفاده از برنامه نویسی نیتیو داشته اند. با به روز شدن امکانات و به وجود آمدن نیاز های مخاطبان، ری اکت به سرعت آپدیت شده و سرعت پیشرفت این کتابخانه ی جاوااسکریپت را در آینده شاهد خواهیم بود.


ری اکتری اکت جی اسفرانت اندreactreact js
طراح رابط و تجربه کاربری ( UI/UX )
شاید از این پست‌ها خوشتان بیاید