در حال بارگذاری...

مدیران بسته (npm/yarn)

مدیران بسته (Package Managers) مانند npm و Yarn ابزارهای حیاتی در توسعه مدرن JavaScript هستند که به شما اجازه می‌دهند کتابخانه‌ها و ماژول‌های جانبی مورد نیاز پروژه را نصب، مدیریت و نسخه‌بندی کنید. می‌توان آن‌ها را مانند کتابدار در یک کتابخانه تصور کرد: هر کتاب یک کتابخانه است و مدیر بسته اطمینان می‌دهد که کتاب‌ها به درستی دسته‌بندی شده، قابل دسترسی و به‌روز باشند. با استفاده از این ابزارها، توسعه‌دهندگان می‌توانند بدون نوشتن مجدد کدهای پایه، ویژگی‌های پیچیده را به پروژه خود اضافه کنند.
در پروژه‌هایی مانند فروشگاه آنلاین، سایت خبری، وبلاگ شخصی یا پورتال دولتی، مدیران بسته امکان نصب و مدیریت کتابخانه‌هایی مانند React، Axios و Lodash را فراهم می‌کنند تا بتوانید درخواست‌های HTTP ارسال کنید، داده‌ها را پردازش کنید یا رابط کاربری پیشرفته ایجاد کنید. آن‌ها همچنین نسخه‌ها را کنترل می‌کنند تا از بروز ناسازگاری و خطا جلوگیری شود. در این آموزش، شما با نحوه ایجاد پروژه، نصب و به‌روزرسانی بسته‌ها، مدیریت فایل‌های package.json و lock و استفاده بهینه از وابستگی‌ها آشنا خواهید شد. استفاده صحیح از npm و Yarn مانند ساختن خانه، تزئین اتاق یا نوشتن نامه است که پروژه شما را منظم، قابل نگهداری و مقیاس‌پذیر می‌کند.

مثال پایه

javascript
JAVASCRIPT Code
// ایجاد پروژه و نصب Axios برای درخواست‌های API
// این کد پس از نصب npm یا yarn به تنهایی اجرا می‌شود

// ایجاد package.json
// npm init -y یا yarn init -y
// نصب کتابخانه Axios
// npm install axios یا yarn add axios

const axios = require('axios'); // وارد کردن کتابخانه

axios.get('[https://jsonplaceholder.typicode.com/posts/1](https://jsonplaceholder.typicode.com/posts/1)') // درخواست GET از API
.then(response => console.log(response.data)) // نمایش داده‌های دریافت شده
.catch(error => console.error('خطا رخ داد:', error)); // مدیریت خطاها

در این مثال، ابتدا با دستور npm init یا yarn init پروژه ایجاد می‌شود و فایل package.json ساخته می‌شود که شامل اطلاعات متا و وابستگی‌های پروژه است. سپس با npm install یا yarn add، کتابخانه Axios نصب می‌شود و به صورت خودکار به dependencies پروژه اضافه می‌گردد. خط const axios = require('axios') کتابخانه را وارد می‌کند تا بتوانید از آن در پروژه استفاده کنید.
متد axios.get یک درخواست HTTP GET ارسال می‌کند و then پاسخ موفق را مدیریت می‌کند، در حالی که catch خطاها را می‌گیرد و لاگ می‌کند. این الگوی asynchronous مانع از مسدود شدن Thread اصلی می‌شود و پاسخ‌دهی را افزایش می‌دهد. برای مبتدیان، فهم package.json، مدیریت وابستگی‌ها و درخواست‌های asynchronous بسیار مهم است. مفهوماً این مرحله مانند بنیاد یک خانه است: بدون مدیریت صحیح وابستگی‌ها، مراحل بعدی توسعه ممکن است ناکارآمد یا دارای خطا باشند.

مثال کاربردی

javascript
JAVASCRIPT Code
// مثال عملی: ایجاد یک API خبری کوچک با Express و Axios
const axios = require('axios');
const express = require('express'); // ایجاد سرور وب

const app = express();

app.get('/news', async (req, res) => {
try {
const response = await axios.get('[https://jsonplaceholder.typicode.com/posts](https://jsonplaceholder.typicode.com/posts)'); // دریافت اخبار
res.json(response.data.slice(0, 5)); // بازگرداندن ۵ خبر اول
} catch (error) {
res.status(500).send('دریافت اخبار موفقیت‌آمیز نبود');
}
});

app.listen(3000, () => console.log('سرور در [http://localhost:3000](http://localhost:3000) در حال اجراست'));

در این مثال عملی، از Express برای ایجاد یک سرور وب ساده استفاده کرده‌ایم و وابستگی‌ها را از طریق npm یا Yarn مدیریت می‌کنیم. کلیدواژه async/await برای مدیریت واضح و قابل نگهداری درخواست‌های asynchronous استفاده شده است. Axios اطلاعات پست‌ها را از یک API خارجی دریافت می‌کند و سرور فقط پنج آیتم اول را بازمی‌گرداند. مدیران بسته تضمین می‌کنند که کتابخانه‌های نصب‌شده سازگار و به‌روز باشند، مشابه چیدمان مناسب وسایل در یک اتاق برای بیشینه کردن فضای مفید و عملکرد.
بهترین روش‌ها شامل قفل کردن نسخه وابستگی‌ها برای جلوگیری از breaking changeها، به‌روزرسانی و تست مرتب کتابخانه‌ها، جدا کردن dependencies و devDependencies برای بهینه‌سازی حجم پروژه و مدیریت صحیح خطاها در عملیات asynchronous است. اشتباهات رایج شامل نصب کتابخانه‌های بلااستفاده، مدیریت نادرست خطاها، استفاده از نسخه‌های ناپایدار و مشکلات مدیریت حافظه هستند. برای Debugging از دستور npm audit یا yarn audit استفاده کنید و lock files را حفظ کنید تا انسجام پروژه در تیم برقرار باشد.

📊 مرجع سریع

Property/Method Description Example
npm init / yarn init ایجاد پروژه و ساخت package.json npm init -y
npm install / yarn add نصب کتابخانه و افزودن آن به پروژه npm install lodash
npm update / yarn upgrade به‌روزرسانی کتابخانه‌ها به آخرین نسخه سازگار npm update axios
npm uninstall / yarn remove حذف کتابخانه از پروژه npm uninstall lodash
package.json ذخیره اطلاعات پروژه و وابستگی‌ها {"name":"project","dependencies":{"axios":"^1.0.0"}}
yarn.lock / package-lock.json قفل کردن نسخه وابستگی‌ها برای انسجام تیمی yarn.lock

خلاصه اینکه npm و Yarn برای مدیریت پروژه‌های JavaScript حیاتی هستند. آن‌ها ساختار و قابلیت نگهداری پروژه را فراهم می‌کنند و اتصال میان دستکاری DOM در Frontend و ارتباط با Backend را ممکن می‌سازند. استفاده مؤثر از این ابزارها امکان توسعه پروژه‌های پیچیده مانند سایت خبری یا فروشگاه آنلاین را ساده می‌کند. گام‌های بعدی پیشنهادی شامل آشنایی با Mono-repos برای پروژه‌های بزرگ، استفاده از npx برای اجرای ابزارهای CLI و بهینه‌سازی caching برای سرعت بیشتر نصب وابستگی‌ها است. تمرین مستمر و کار روی پروژه‌های واقعی کمک می‌کند تا وابستگی‌ها به شکل یک کتابخانه منظم مدیریت شوند و کدهای پایدار و قابل نگهداری ایجاد گردد.

🧠 دانش خود را بیازمایید

آماده شروع

آزمون دانش شما

درک خود از این موضوع را با سوالات کاربردی بسنجید.

3
سوالات
🎯
70%
برای قبولی
♾️
زمان
🔄
تلاش‌ها

📝 دستورالعمل‌ها

  • هر سوال را با دقت بخوانید
  • بهترین پاسخ را برای هر سوال انتخاب کنید
  • می‌توانید آزمون را هر چند بار که می‌خواهید تکرار کنید
  • پیشرفت شما در بالا نمایش داده می‌شود