الفرق بين المراجعتين لصفحة: «jQuery/addClass»

من موسوعة حسوب
لا ملخص تعديل
لا ملخص تعديل
 
(مراجعة متوسطة واحدة بواسطة مستخدم واحد آخر غير معروضة)
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE:التابع <code>‎‎.addClass()‎‎</code>‎ في jQuery}}</noinclude>
<noinclude>{{DISPLAYTITLE:التابع <code>‎‎.addClass()‎‎</code>‎ في jQuery}}</noinclude>
== <code>‎.addClass( className )‎</code> ==
== <code>‎.addClass( className )‎</code> ==


سطر 48: سطر 47:
<head>
<head>
   <meta charset="utf-8">
   <meta charset="utf-8">
   <title>addClass demo</title>
   <title>addClass مثال عن التابع</title>
   <style>
   <style>
   p {
   p {
سطر 65: سطر 64:
<body>
<body>
   
   
<p>Hello</p>
<p>مرحبًا</p>
<p>and</p>
<p>و</p>
<p>Goodbye</p>
<p>وداعًا</p>
   
   
<script>
<script>
سطر 81: سطر 80:
<head>
<head>
   <meta charset="utf-8">
   <meta charset="utf-8">
   <title>addClass demo</title>
   <title>addClass مثال عن التابع</title>
   <style>
   <style>
   p {
   p {
سطر 98: سطر 97:
<body>
<body>
   
   
<p>Hello</p>
<p>مرحبًا</p>
<p>and</p>
<p>و</p>
<p>Goodbye</p>
<p>وداعًا</p>
   
   
<script>
<script>
سطر 114: سطر 113:
<head>
<head>
   <meta charset="utf-8">
   <meta charset="utf-8">
   <title>addClass demo</title>
   <title>addClass مثال عن التابع</title>
   <style>
   <style>
   div {
   div {
سطر 130: سطر 129:
<body>
<body>
   
   
  <div>This div should be white</div>
  <div>يجب أن يكون هذا العنصر أبيض</div>
  <div class="red">This div will be green because it now has the "green" and "red" classes.
  <div class="red">سيكون هذا العنصر أخضر لأنه يمتلك الصنفين green و red
   It would be red if the addClass function failed.</div>
   سيكون أحمرًا إن فشل تنفيذ التابع addClass</div>
  <div>This div should be white</div>
  <div>يجب أن يكون هذا العنصر أبيض</div>
  <p>There are zero green divs</p>
  <p>لا يوجد هنا أي عنصر div أخضر</p>
   
   
<script>
<script>
سطر 142: سطر 141:
   if ( currentClass === "red" ) {
   if ( currentClass === "red" ) {
     addedClass = "green";
     addedClass = "green";
     $( "p" ).text( "There is one green div" );
     $( "p" ).text( "هنالك عنصر div أخضر وحيد" );
   }
   }
   
   

المراجعة الحالية بتاريخ 23:31، 1 يونيو 2018

‎.addClass( className )‎

القيمة المعادة

كائن jQuery.

الوصف

يُستخدَم التّابع ‎.addClass()‎ لإضافة الصّنف أو الأصناف المُحدَّدة لكل عنصر من مجموعة العناصر المُطابقة.

‎.addClass( className )‎

أضيفت في الإصدار: 1.0.

className

سلسلة نصيّة من الكائن String، وتُمثِّل صنف أو عدة أصناف مفصولة بمسافة بينها لإضافتها إلى الخاصيّة class لكل عنصر مُطابق.

‎.addClass( function )‎

أضيفت في الإصدار: 1.4.

Function

دالة على الشكل Function( Integer index, String currentClassName )‎ وتُعيد سلسلة نصيّة.

دالة تُعيد اسم أو عدة أسماء لأصناف مفصولةً بمسافة بينها لإضافتها إلى اسم الصّنف أو أسماء الأصناف الموجودة. المعامل this يمثِّل العنصر الحالي. تستقبل فهرس موقع العنصر في المجموعة واسم أو أسماء الأصناف الموجودة كوسائط لها.

من المهم أن نلاحظ أن هذا التّابع لا يستبدل الصّنف الحالي، بل يضيفه ببساطة ملحقًا إياه بأي صنف معين مسبقًا للعناصر.

قبل إصدار jQuery 1.2/2.2 كان التّابع ‎.addClass()‎ يتحكم بخاصيّة الكائن className للعناصر المحدّدة وليس بخاصيّة HTML ‏class‏، وحالما تتغيّر خاصيّة الكائن يُحدِّث المتصفّح خاصيّة HTML وفق ذلك، وتفسير هذا السّلوك هو أنّ هذا التّابع كان يعمل فقط للمستندات ذات الصّياغة HTML DOM (أي ليس على مستندات XML الصَرفة [pure XML]).

تغيّر هذا السّلوك بدءًا من إصدار jQuery 1.12/2.2 لتحسين الدّعم لمستندات XML وتضمين مستندات SVG أيضًا. وبدءًا من هذا الإصدار استُخدِمَت خاصيّة HTML ‏class بدلًا من ذلك، لذا يُمكِن استخدام التّابع ‎.addClass()‎ مع مستندات XML أو SVG.

من الممكن إضافة أكثر من صنف في نفس الوقت، مفصولةً بمسافة بينها، إلى مجموعة العناصر المُطابقة كما يلي:

$( "p" ).addClass( "myClass yourClass" );

يُستَخدَم هذا التّابع عادةً مع التّابع ‎.removeClass()‎ للتبديل بين أصناف العناصر من صنف إلى آخر، كما يلي:

$( "p" ).removeClass( "myClass noClass" ).addClass( "yourClass" );

أُزيل هنا الصّنفان myClass و noClass من كل الفقرات <p> وأُضيف الصّنف yourClass. بدءًا من إصدار jQuery 1.4 أصبح التّابع ‎.addClass()‎ قادرًا على استقبال دالة كوسيط:

$( "ul li" ).addClass(function( index ) {
  return "item-" + index;
});

انطلاقًا من قائمة غير مُرتّبة تحتوي على عنصري <li> يُضيف هذا المثال الصّنف ‎"item-0"‎ لعنصر <li> الأول و ‎"item-1"‎ للعنصر الثاني .

أمثلة

إضافة الصّنف ‎"selected"‎ للعناصر المُطابقة:

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>addClass مثال عن التابع</title>
  <style>
  p {
    margin: 8px;
    font-size: 16px;
  }
  .selected {
    color: blue;
  }
  .highlight {
    background: yellow;
  }
  </style>
  <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
 
<p>مرحبًا</p>
<p>و</p>
<p>وداعًا</p>
 
<script>
$( "p" ).last().addClass( "selected" );
</script>
 
</body>
</html>

إضافة الأصناف ‎"selected"‎ و ‎"highlight"‎ للعناصر المُطابقة:

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>addClass مثال عن التابع</title>
  <style>
  p {
    margin: 8px;
    font-size: 16px;
  }
  .selected {
    color: red;
  }
  .highlight {
    background: yellow;
  }
  </style>
  <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
 
<p>مرحبًا</p>
<p>و</p>
<p>وداعًا</p>
 
<script>
$( "p:last" ).addClass( "selected highlight" );
</script>
 
</body>
</html>

تمرير دالة إلى التّابع ‎.addClass()‎ لإضافة الصّنف ‎"green"‎ إلى عنصر <div> يملك مسبقًا الصّنف‎"red" ‎:

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>addClass مثال عن التابع</title>
  <style>
  div {
    background: white;
  }
  .red {
    background: red;
  }
  .red.green {
    background: green;
  }
  </style>
  <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
</head>
<body>
 
 <div>يجب أن يكون هذا العنصر أبيض</div>
 <div class="red">سيكون هذا العنصر أخضر لأنه يمتلك الصنفين green و red
   سيكون أحمرًا إن فشل تنفيذ التابع addClass</div>
 <div>يجب أن يكون هذا العنصر أبيض</div>
 <p>لا يوجد هنا أي عنصر div أخضر</p>
 
<script>
$( "div" ).addClass(function( index, currentClass ) {
  var addedClass;
 
  if ( currentClass === "red" ) {
    addedClass = "green";
    $( "p" ).text( "هنالك عنصر div أخضر وحيد" );
  }
 
  return addedClass;
});
</script>
 
</body>
</html>

مصادر