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

الفرق بين classList و setAttribute في جافا سكريبت؟

zainb mohd

السؤال

Recommended Posts

  • 1

الدالة setAttribute تستخدم لإضافة أى صفة خاصة بالعنصر ولا تقتصر علي ال class فقط . 

فيمكنك إضافة إسم للعنصر أو حتى جعله غير مفعل .

el.setAttribute("name", "Any_Name");
el.setAttribute("disabled", "");

وهذه الدالة تقوم بمسح القيمة القديمة للصفة وتوضع القيمة الجديدة فإذا قمنا باستخدام صفة class 

فسوف تقوم بمسح جيمع ال classes الخاصة بالعنصر واضافة ما تم ارساله لها 

za.setAttribute("class", "one");  // هنا سوف تقوم بمسح جميع لاصناف ووضع الصنف one فقط

إذا الكود السابق سوف يقوم بمسح جميع الاصناف ووضع الصنف one فقط .

اما بالنسبة للخاصية classList فهي خاصة بالعنصر للتلاعب بالاصناف وتحتوى على دوال كثيرة تسهل العمل .

contslide.classList.add('one') // هنا سوف تقوم بإضافة الصنف onde على باقى الاصناف 


contslide.classList.remove('one') //  هنا سوف تقوم بحذف الصنف فقط 




contslide.classList.toggle('one')  // هنا سوف تقوم بحذف الصنف إذا وجد أو ستقوم بإضافته إذا لم يوجد

هنا في أول سطر سوف تقوم بإضافة الصنف one الى قائمة الاصناف وبذلك لن يفقد العنصر الاصناف الخاصة به .

إذا فإن الفرق بينهم هو ان setAtrribute ستقوم بحذف باقى الاصناف واضافة الصنف المرسل لها فقط .

و classList.add ستقوم بالحفاظ على الاصناف السابقة مع إضافة الصنف الجديد .

ولذلك فإن الافضل هو استخدام classList لاحتوائها على اكثر من دالة تقوم بتسهيل العمل وخاصة بالاصناف فقط 

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

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

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

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

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   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.

  • إعلانات

  • تابعنا على



×
×
  • أضف...