إتقان التكرار غير المتزامن في 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)، فهتكون إضافة قوية جداً لمكتبتك كمطور.

المدونة

حقق أداءً أعلى لتقارير البيانات الضخمة باستخدام نظام (Queues)

يوليو 07, 2025

إزاي نعمل كاش لتقارير بفترة زمنية ثابتة إزاي نولّد تقارير ضخمة في الخلفية باستخدام الـ Job Queues 1. 🧠 كاش للتقارير بفترة زمنية ثابتة لو ع...

كيف تجعل موقعك "سريع جداً" خطوة بخطوة

يوليو 30, 2025

لماذا السرعة ليست رفاهية؟ في زمن الضغط والسرعة، ما فيش حد عنده وقت يستنى موقع يحمّل! المستخدمين على الموبايل بينسحبوا من الموقع إذا ما فتحش في أق...

تعزيز PHP Enums باستخدام archtechx/enums

يوليو 01, 2025

تعزيز PHP enums باستخدام حزمة archtechx/enums من PHP&nbsp;8.1، ظهر نوع جديد اسمه &ldquo;enums&rdquo; بيخليك تعرف قيم ثابتة بأسماء مرمّزة زي statuses...

استدعاء ملفات JavaScript عند الحاجة فقط لتحسين أداء موقعك

يوليو 24, 2025

🧠 يعني إيه Dynamic Import؟ الديناميـك إمبورت ببساطة هو إنك تحمّل ملف أو موديول JavaScript "وقت الحاجة بس" مش من أول الصفحة. الميزة دي بتقلل حجم ال...

أحدث مميزات ECMAScript 2025

يونيو 30, 2025

أحدث مميزات ECMAScript 2025 في 25 يونيو 2025، تم اعتماد ES2025 رسميًا. الإضافات الجاية هتسهل عليك كتابة الكود: 1. 📦 Import Attributes و JSON Module...

البرمجة الكائنية (OOP) – المفاهيم الأساسية

أغسطس 09, 2025

البرمجة الكائنية التوجه (Object Oriented Programming - OOP) هي أسلوب حديث في تطوير البرمجيات يُقسّم التطبيق إلى وحدات تسمى كائنات (Objects) تتفاعل م...

The Ultimate Managed Hosting Platform