إتقان التكرار غير المتزامن في JavaScript باستخدام Array.fromAsync()
يوليو 27, 2025🔍 ما هي Array.fromAsync() بالضبط؟
Array.fromAsync() هي دالة static من كائن Array، شبيهة بالدالة Array.from()، لكن الفرق الجوهري هو أن Array.fromAsync() تدعم المعطيات الغير متزامنة: سواء كانت AsyncIterable أو دالة map ترجع Promise. هذه الوظيفة تسهّل التعامل مع البيانات المتدفقة من مصادر خارجية أو مؤجلة زمنياً.
🧪 مثال عملي: التعامل مع Async Generator
في هذا المثال نستخدم async function* لإنتاج أرقام بطريقة غير متزامنة:
async function* fetchValues() {
for (let i = 1; i <= 3; i++) {
await new Promise(resolve => setTimeout(resolve, 500)); // محاكاة تأخير زمني
yield i;
}
}
const result = await Array.fromAsync(fetchValues());
console.log(result); // [1, 2, 3]
🔁 استخدام Array.fromAsync() مع دالة تحويل Asynchronous
في هذا المثال، نُضاعف كل عنصر في المصفوفة باستخدام دالة async:
const values = [10, 20, 30];
const doubled = await Array.fromAsync(values, async (num) => {
await new Promise(resolve => setTimeout(resolve, 300));
return num * 2;
});
console.log(doubled); // [20, 40, 60]
📦 مقارنة مع for await...of
بالرغم من أن for await...of توفر طريقة ممتازة للتعامل مع الـ AsyncIterable، إلا أنها تتطلب كتابة يدوية أكثر:
let output = [];
for await (const item of fetchValues()) {
output.push(item);
}
بينما Array.fromAsync() تقوم بنفس الوظيفة بسطر واحد أكثر نظافة:
const output = await Array.fromAsync(fetchValues());
💼 حالات استخدام حقيقية
- معالجة البيانات المسترجعة من API بتأخير زمني
- جمع نتائج عمليات async مثل تحميل الملفات أو الصور
- تحويل سلاسل streams إلى مصفوفات مباشرة
⚠️ ملاحظات
- الدالة
Array.fromAsync()ترجع Promise، لذا تأكد من استخدامawaitأو.then() - في حال كنت تستخدم بيئة لا تدعم ES2024 بعد، يمكنك استخدام Babel أو Polyfill.
- حاول استخدام async map بحذر لتجنب تشغيل كل المهام بالتوازي في حال كانت ثقيلة.
📌 خلاصة
Array.fromAsync() تمثل نقلة نوعية في التفاعل مع البيانات غير المتزامنة في JavaScript. بفضل بساطتها وقوتها، توفر طريقة مرنة وعملية لتجميع البيانات في سيناريوهات كثيرة. إذا كنت تبني تطبيقات تعتمد على الـ APIs، أو التعامل مع تدفقات البيانات (streams)، فهتكون إضافة قوية جداً لمكتبتك كمطور.
المدونة
يوليو 07, 2025
إزاي نعمل كاش لتقارير بفترة زمنية ثابتة إزاي نولّد تقارير ضخمة في الخلفية باستخدام الـ Job Queues 1. 🧠 كاش للتقارير بفترة زمنية ثابتة لو ع...
يوليو 30, 2025
لماذا السرعة ليست رفاهية؟ في زمن الضغط والسرعة، ما فيش حد عنده وقت يستنى موقع يحمّل! المستخدمين على الموبايل بينسحبوا من الموقع إذا ما فتحش في أق...
يوليو 01, 2025
تعزيز PHP enums باستخدام حزمة archtechx/enums من PHP 8.1، ظهر نوع جديد اسمه “enums” بيخليك تعرف قيم ثابتة بأسماء مرمّزة زي statuses...
يوليو 24, 2025
🧠 يعني إيه Dynamic Import؟ الديناميـك إمبورت ببساطة هو إنك تحمّل ملف أو موديول JavaScript "وقت الحاجة بس" مش من أول الصفحة. الميزة دي بتقلل حجم ال...
يونيو 30, 2025
أحدث مميزات ECMAScript 2025 في 25 يونيو 2025، تم اعتماد ES2025 رسميًا. الإضافات الجاية هتسهل عليك كتابة الكود: 1. 📦 Import Attributes و JSON Module...
أغسطس 09, 2025
البرمجة الكائنية التوجه (Object Oriented Programming - OOP) هي أسلوب حديث في تطوير البرمجيات يُقسّم التطبيق إلى وحدات تسمى كائنات (Objects) تتفاعل م...