"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > تعبير الوظيفة الذي تم استدعاؤه فورًا (IIFE)

تعبير الوظيفة الذي تم استدعاؤه فورًا (IIFE)

تم النشر بتاريخ 2024-11-07
تصفح:299

Immediately Invoked Function Expression (IIFE)

تعبير الوظيفة الذي يتم استدعاؤه فورًا (IIFE) هو وظيفة JavaScript يتم تشغيلها بمجرد تعريفها. يتم استخدامه بشكل شائع لتجنب تلويث النطاق العالمي أو لإنشاء نطاق خاص للمتغيرات.

إليك مثال بسيط على IIFE:

(function() {
    var message = "Hello from IIFE!";
    console.log(message);
})();

توضيح:

  • الدالة محاطة بين قوسين: (function() { ... }). وهذا يجعل محرك جافا سكريبت يتعامل معها كتعبير.
  • مباشرة بعد قوس إغلاق الدالة، تتم إضافة مجموعة أخرى من الأقواس () لاستدعاء الدالة على الفور.
  • تعمل الوظيفة مباشرة بعد تعريفها، وتسجيل "مرحبًا من IIFE!" إلى وحدة التحكم.

الإخراج:

Hello from IIFE!

الاستخدام:

تعتبر IIFEs مفيدة عندما تريد إنشاء نطاق جديد، خاصة لحماية المتغيرات من الوصول إليها أو تعديلها خارج الوظيفة:

(function() {
    var counter = 0;  
// This counter is private and can't be accessed from outside

    function increment() {
        counter  ;
        console.log(counter);
    }

    increment(); // Logs: 1
    increment(); // Logs: 2
})();

console.log(typeof counter); 
// Logs: "undefined", because `counter` is not accessible here.

يضمن هذا أن تظل المتغيرات مثل العداد خاصة ولا يتم تعديلها عن طريق الخطأ أو الوصول إليها من أجزاء أخرى من الكود.

بيان الافراج تم إعادة نشر هذه المقالة على: https://dev.to/pranavbakare/immediately-invoced-function-expression-iife-3m1l?1 إذا كان هناك أي انتهاك، يرجى الاتصال بـ [email protected] لحذفه
أحدث البرنامج التعليمي أكثر>

تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.

Copyright© 2022 湘ICP备2022001581号-3