اذهب إلى المحتوى
  • 0

هل بإمكاني تمرير كائن في دالة Onclick على JaveScript؟

K@m@l

السؤال

أريد تمرير كائن Object  في دالة OnClick باستخدام لغة JavaScript؟ 

هذا ما أريده:

<script type="text/javascript">

//The constructor :
function Foo()
{   
    /*  div إضافة الوسم*/
    div_element = document.createElement("div");
    document.body.insertBefore(div_element, null);

    /*إخفاء الوسم */
    this.hide = function()
    {
        div_element.style.display = "none";
    }

    /*إضافة زر بداخل الوسم مرتبظ بحدث الإخفاء*/
    div_element.innerHTML = '<input type="button" value="Hide" onclick="this.hide();">';
}

foo = new Foo();

</script>

 

رابط هذا التعليق
شارك على الشبكات الإجتماعية

Recommended Posts

  • 0

مبدأيًا الكائن foo يوجد ضمن مجاله الدالة وبالتالي فالدالة hide ستطبق عليها لأنه وبكل بساطة سيتعرف عليها إذ استخدمت داخل نطاقه ولن تعتبر النافذة هي this في هذه الحالة.

أيضا استعمل الكلمة var لتعريف متغير فيصبح تعريفك للوسم بهذه الطريقة :

    var div_element = document.createElement('div');

ليكون الكود البرمجي بشكل صحيح هو:

function Foo()
{   
    var div_element = document.createElement('div');

    this.hide = function()
    {
        div_element.style.display = 'none';
    }

    // زر الإخفاء
    var btn = document.createElement('input');
    btn.type = 'button';
    btn.value = 'Hide';
    btn.onclick = this.hide;

    // إضافة الزر إلى الوسم
    div_element.appendChild(btn);

    // إضافة الكل إلى الصفحة
    document.body.insertBefore(div_element, null);
}

foo = new Foo();

 

رابط هذا التعليق
شارك على الشبكات الإجتماعية

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...