دانش کامپیوتر

دانش کامپیوتر

در این بخش، به دنیای برنامه‌نویسی، الگوریتم‌ها، شبکه و زیرساخت‌های فناوری می‌پردازیم

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

Related Categories

Featured Articles

ساید افکت‌ها در React – همگام‌سازی وضعیت با localStorage با استفاده از useEffect

در React، خروجی کامپوننت‌ها معمولاً بر اساس پراپس‌ها و وضعیت (state) تعیین می‌شود. اما گاهی نیاز داریم با منابع خارجی مانند localStorage یا APIها تعامل داشته باشیم. این مقاله نحوهٔ استفاده از hook معروف useEffect برای مدیریت ساید افکت‌ها، همگام‌سازی وضعیت با localStorage، و بهبود تجربه کاربری را بررسی می‌کند.

/article/react-side-effects-sync-state-with-localstorage-useeffect-fa

هوک‌های سفارشی در React – ساخت useStorageState برای همگام‌سازی وضعیت با localStorage

در React، هوک‌های useState و useEffect برای مدیریت وضعیت و ساید افکت‌ها بسیار کاربردی هستند. این مقاله نحوهٔ ساخت یک هوک سفارشی به نام useStorageState را آموزش می‌دهد که وضعیت کامپوننت را با localStorage مرورگر همگام می‌کند. همچنین با اصول نام‌گذاری، بازگشت آرایه‌ای، و قابلیت استفاده مجدد در هوک‌های سفارشی آشنا می‌شویم.

/article/react-custom-hooks-sync-state-with-localstorage-fa

React Fragments و طراحی کامپوننت‌های قابل استفاده مجدد

در React، کامپوننت‌ها باید فقط یک عنصر ریشه‌ای بازگردانند. برای جلوگیری از اضافه شدن عناصر اضافی به DOM، می‌توان از Fragment استفاده کرد. این مقاله نحوهٔ استفاده از Fragment و نسخهٔ خلاصه‌شدهٔ آن را بررسی می‌کند. همچنین با بازطراحی کامپوننت Search به InputWithLabel، مفهوم کامپوننت‌های قابل استفاده مجدد را معرفی می‌کنیم.

/article/react-fragments-and-reusable-component-design-fa

ترکیب کامپوننت‌ها و دسترسی امری در React – استفاده از children و کنترل فوکوس با useRef

در React می‌توان کامپوننت‌ها را مانند عناصر HTML با تگ باز و بسته استفاده کرد. این مقاله نحوهٔ استفاده از پراپ children برای ترکیب کامپوننت‌ها، و نحوهٔ دسترسی امری به عناصر DOM با استفاده از useRef و useEffect را بررسی می‌کند. همچنین کامپوننت ورودی قابل استفاده مجدد را طوری بازطراحی می‌کنیم که هم به‌صورت declarative و هم imperative قابل کنترل باشد.

/article/react-component-composition-and-imperative-access-fa

هندلرهای درون‌خطی در JSX – حذف آیتم‌ها با رویکردی ساده و قابل خواندن

در React، هندلرهای درون‌خطی راهی ساده و مؤثر برای اجرای توابع در JSX هستند. این مقاله نحوهٔ استفاده از هندلرهای درون‌خطی برای حذف آیتم‌ها از لیست را بررسی می‌کند. با استفاده از useState، callback handler و تابع فیلتر، لیست را به‌صورت پویا مدیریت می‌کنیم و با استفاده از arrow function یا bind، هندلر حذف را مستقیماً در JSX تعریف می‌کنیم.

/article/Inline Handlers in JSX – Removing Items with Concise and Readable Logic-fa

داده‌های غیرهمزمان در React – شبیه‌سازی دریافت داده از API با useEffect و Promise

در React، داده‌ها معمولاً از منابع خارجی به‌صورت غیرهمزمان دریافت می‌شوند. این مقاله نحوهٔ شبیه‌سازی دریافت داده از API با استفاده از Promise و useEffect را بررسی می‌کند. ابتدا داده‌های نمونه را به‌صورت غیرهمزمان بارگذاری می‌کنیم، سپس با تأخیر ۲ ثانیه‌ای، رفتار واقعی‌تری از دریافت داده را پیاده‌سازی می‌کنیم. این گام نخست برای اتصال به API واقعی در آینده است.

/article/react-async-data-simulate-api-with-useeffect-fa

رندر شرطی در React – نمایش وضعیت بارگذاری و خطا هنگام دریافت داده‌های غیرهمزمان

در React، رندر شرطی ابزاری قدرتمند برای کنترل نمایش رابط کاربری بر اساس وضعیت‌های مختلف است. این مقاله نحوهٔ نمایش پیام «در حال بارگذاری…» هنگام دریافت داده‌های غیرهمزمان، و پیام خطا در صورت شکست دریافت داده را بررسی می‌کند. با استفاده از useState و useEffect، وضعیت‌های isLoading و isError را مدیریت کرده و با استفاده از عملگرهای منطقی و ternary، رندر شرطی را پیاده‌سازی می‌کنیم.

/article/react-conditional-rendering-loading-error-states-fa

مدیریت پیشرفته وضعیت در React – استفاده از useReducer برای انتقال‌های پیچیده

در حالی که useState برای مدیریت وضعیت‌های ساده مناسب است، هوک useReducer در React راه‌حلی مقیاس‌پذیر برای مدیریت وضعیت‌های پیچیده و وابسته ارائه می‌دهد. این مقاله نحوهٔ مهاجرت وضعیت لیست داستان‌ها از useState به useReducer را بررسی می‌کند، و نشان می‌دهد چگونه با تعریف اکشن‌هایی مانند SET_STORIES و REMOVE_STORY می‌توان منطق وضعیت را به‌صورت متمرکز و خوانا مدیریت کرد.

/article/react-advanced-state-management-with-usereducer-fa

وضعیت‌های غیرممکن در React – مدیریت پیش‌بینی‌پذیر وضعیت با useReducer

استفاده هم‌زمان از چند useState برای مدیریت وضعیت‌های مرتبط می‌تواند منجر به وضعیت‌های غیرممکن و باگ‌های پنهان شود. این مقاله نشان می‌دهد چگونه با ترکیب وضعیت‌های مرتبط در یک useReducer واحد، می‌توان از بروز چنین مشکلاتی جلوگیری کرد. با تعریف یک ساختار وضعیت پیچیده شامل داده، بارگذاری و خطا، و استفاده از اکشن‌های مشخص، مدیریت وضعیت در React پیش‌بینی‌پذیرتر و قابل اطمینان‌تر می‌شود.

/article/react-impossible-states-predictable-management-with-usereducer-fa

دریافت صریح داده‌ها در React – کنترل درخواست‌های API با دکمه تأیید

در پیاده‌سازی اولیه، هر بار که کاربر در فیلد جستجو تایپ می‌کرد، درخواست جدیدی به API ارسال می‌شد. این مقاله نحوهٔ تغییر این رفتار به دریافت صریح داده‌ها را آموزش می‌دهد؛ به‌طوری‌که فقط با کلیک روی دکمهٔ تأیید، درخواست به API ارسال شود. با تعریف دو وضعیت مجزا برای searchTerm و url، و استفاده از useCallback و useEffect، کنترل کامل بر زمان ارسال درخواست فراهم می‌شود.

/article/react-explicit-data-fetching-with-confirm-button-fa

کتابخانه‌های شخص ثالث در React – استفاده از axios و async/await برای دریافت داده‌ها

در این مقاله، نحوهٔ جایگزینی fetch با کتابخانهٔ axios برای دریافت داده‌ها از API در React را بررسی می‌کنیم. سپس با استفاده از async/await و بلوک try/catch، کد دریافت داده‌ها را خواناتر و قابل مدیریت‌تر می‌کنیم. این روش‌ها باعث افزایش سازگاری با مرورگرهای قدیمی، بهبود تست‌پذیری، و کاهش پیچیدگی کد می‌شوند.

/article/react-third-party-libraries-axios-async-await-fa

فرم‌ها در React – ارسال داده با onSubmit و action در فرم‌های جستجو

فرم‌ها بخش جدایی‌ناپذیر هر اپلیکیشن مدرن هستند. در این مقاله، نحوهٔ ساخت فرم جستجو در React را بررسی می‌کنیم. ابتدا از onSubmit برای مدیریت ارسال فرم استفاده می‌کنیم و سپس با معرفی ویژگی action، فرم را به رفتار بومی HTML نزدیک‌تر می‌کنیم. این ساختار باعث افزایش خوانایی، قابلیت استفاده با صفحه‌کلید، و آمادگی برای نسخه‌های آیندهٔ React می‌شود.

/article/react-forms-submit-search-with-onsubmit-and-action-fa
دانش کامپیوتر | Dr. Shahin Siami