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

من موسوعة حسوب
إنشاء الصفحة
 
لا ملخص تعديل
 
(3 مراجعات متوسطة بواسطة مستخدمين اثنين آخرين غير معروضة)
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE:مكوِّن الطيّ Collapse في إطار العمل Bootstrap}}</noinclude>
استخدِم أصناف مكوِّن الطيّ ومُلحقات JavaScript في إطار العمل Bootstrap لإظهار المحتوى أو إخفائه حسب الحاجة.
استخدِم أصناف مكوِّن الطيّ ومُلحقات JavaScript في إطار العمل Bootstrap لإظهار المحتوى أو إخفائه حسب الحاجة.
== نظرة عامة ==
يُستخدم مكوِّن الطيّ لإظهار وإخفاء المحتوى. تُستخدم الأزرار أو المنقورات كمنشّطات لإظهار أو إخفاء عنصر معين ترتبط به. سيؤدي تصغير عنصر إلى تحريك الارتفاع من قيمته الحالية إلى <code>0</code>. ونظرًا للطريقة التي تتعامل بها CSS مع الحركات، لا يمكنك استخدام الحواشي على عنصر <code>.collapse</code>. استخدم بدلاً من ذلك الصنف كعنصر مغلِّف مستقل.
'''ملحوظة''': تأثير الحركة الخاص بهذه المكونة يعتمد على استعلام الوسائط <code>prefers-reduced-motion</code>. راجع [[Bootstrap/accessibility|صفحة سهولة الوصول]] لمزيد من المعلومات.


== مثال ==
== مثال ==
سطر 26: سطر 32:


== أهداف متعدّدة ==
== أهداف متعدّدة ==
يمكن لزرّ (<code><button></code>) أو رابط (<code><a></code>) إظهار عناصر عدّة أو إخفاؤها بالإحالة إلى محدِّد jQuery في الخاصيّة <code>href</code> أو <code>data-target</code> حسب الحالة.
يمكن لزرّ (<code>[[HTML/button|<button>]]</code>) أو رابط (<code></code>) إظهار عناصر عدّة أو إخفاؤها بالإحالة إلى محدِّد jQuery في الخاصيّة <code>href</code> أو <code>data-target</code> حسب الحالة.


يمكن لأزرار أو روابط عدّة إظهار أو إخفاء نفس العنصُر إن كانت كلّها تحيل إلى خاصيّة <code>href</code> أو <code>data-target</code> في العنصُر المذكور.<syntaxhighlight lang="html">
يمكن لأزرار أو روابط عدّة إظهار أو إخفاء نفس العنصُر إن كانت كلّها تحيل إلى خاصيّة <code>href</code> أو <code>data-target</code> في العنصُر المذكور.<syntaxhighlight lang="html">
سطر 56: سطر 62:
== تأثير الأكورديون ==
== تأثير الأكورديون ==
يمكن باستخدام مكوِّن [[Bootstrap/card|البطاقات]] في إطار العمل Bootstrap تمديد سلوك الطيّ المبدئي لإنشاء تأثير يشبه حركة آلة [https://ar.wikipedia.org/wiki/%D8%A3%D9%83%D9%88%D8%B1%D8%AF%D9%8A%D9%88%D9%86 الأكورديون] الموسيقية.<syntaxhighlight lang="html">
يمكن باستخدام مكوِّن [[Bootstrap/card|البطاقات]] في إطار العمل Bootstrap تمديد سلوك الطيّ المبدئي لإنشاء تأثير يشبه حركة آلة [https://ar.wikipedia.org/wiki/%D8%A3%D9%83%D9%88%D8%B1%D8%AF%D9%8A%D9%88%D9%86 الأكورديون] الموسيقية.<syntaxhighlight lang="html">
<div id="accordion">
<div class="accordion" id="accordionExample">
   <div class="card">
   <div class="card">
     <div class="card-header" id="headingOne">
     <div class="card-header" id="headingOne">
       <h5 class="mb-0">
       <h2 class="mb-0">
         <button class="btn btn-link" data-toggle="collapse" data-target="#collapseOne" aria-expanded="true" aria-controls="collapseOne">
         <button class="btn btn-link btn-block text-left" type="button" data-toggle="collapse" data-target="#collapseOne" aria-expanded="true" aria-controls="collapseOne">
           العنصُر الأوّل القابل للطيّ
           العنصُر الأوّل القابل للطيّ
         </button>
         </button>
       </h5>
       </h2>
     </div>
     </div>


     <div id="collapseOne" class="collapse show" aria-labelledby="headingOne" data-parent="#accordion">
     <div id="collapseOne" class="collapse show" aria-labelledby="headingOne" data-parent="#accordionExample">
       <div class="card-body">
       <div class="card-body">
         تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
         تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
سطر 74: سطر 80:
   <div class="card">
   <div class="card">
     <div class="card-header" id="headingTwo">
     <div class="card-header" id="headingTwo">
       <h5 class="mb-0">
       <h2 class="mb-0">
         <button class="btn btn-link collapsed" data-toggle="collapse" data-target="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo">
         <button class="btn btn-link btn-block text-left collapsed" type="button" data-toggle="collapse" data-target="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo">
           العنصُر الثاني القابل للطيّ
           العنصُر الثاني القابل للطيّ
         </button>
         </button>
       </h5>
       </h2>
     </div>
     </div>
     <div id="collapseTwo" class="collapse" aria-labelledby="headingTwo" data-parent="#accordion">
     <div id="collapseTwo" class="collapse" aria-labelledby="headingTwo" data-parent="#accordionExample">
       <div class="card-body">
       <div class="card-body">
         تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
         تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
سطر 88: سطر 94:
   <div class="card">
   <div class="card">
     <div class="card-header" id="headingThree">
     <div class="card-header" id="headingThree">
       <h5 class="mb-0">
       <h2 class="mb-0">
         <button class="btn btn-link collapsed" data-toggle="collapse" data-target="#collapseThree" aria-expanded="false" aria-controls="collapseThree">
         <button class="btn btn-link btn-block text-left collapsed" type="button" data-toggle="collapse" data-target="#collapseThree" aria-expanded="false" aria-controls="collapseThree">
           العنصُر الثالث القابل للطيّ
           العنصُر الثالث القابل للطيّ
         </button>
         </button>
       </h5>
       </h2>
     </div>
     </div>
     <div id="collapseThree" class="collapse" aria-labelledby="headingThree" data-parent="#accordion">
     <div id="collapseThree" class="collapse" aria-labelledby="headingThree" data-parent="#accordionExample">
       <div class="card-body">
       <div class="card-body">       تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
        تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
       </div>
       </div>
     </div>
     </div>
سطر 106: سطر 111:


== سهولة الوصول ==
== سهولة الوصول ==
تأكّد من إضافة الخاصيّة <code>aria-expanded</code> إلى عنصُر التحكّم. تنقُل هذه الخاصيّة الحالة الراهنة للعنصُر القابل للطيّ تنقُلها إلى قارئات الشاشة والتقنيّات المساعدة المشابهة. يجب أن تكون قيمة الخاصيّة هي <code>aria-expanded="false"‎</code> إنْ كان العنصُر القابل للطيّ مغلقًا مبدئيّا. عيّن القيمة <code>true</code> للخاصيّة <code>aria-expanded</code> إنْ كان العنصُر القابل للطيّ ظاهرًا مبدئيًّا نتيجة لاستخدام الصنف <code>show</code>. يبدّل المُلحَق قيمة الخاصيّة تلقائيًّا في عنصُر التحكّم اعتمادًا على ما إذا كان العنصُر القابل للطيّ مُظهَرًا أم مخفيًّا (عن طريق JavaScript أو عندما يستخدم الزائر عنصُر تحكّم آخر مربوطًا بنفس العنصُر القابل للطيّ). إنْ لم يكن عنصُر التحكم زرًّا (<code><button></code>) فتجب إضافة الخاصيّة <code>role="button"‎</code> إليه.
تأكّد من إضافة الخاصيّة <code>aria-expanded</code> إلى عنصُر التحكّم. تنقُل هذه الخاصيّة الحالة الراهنة للعنصُر القابل للطيّ تنقُلها إلى قارئات الشاشة والتقنيّات المساعدة المشابهة. يجب أن تكون قيمة الخاصيّة هي <code>aria-expanded="false"‎</code> إنْ كان العنصُر القابل للطيّ مغلقًا مبدئيّا. عيّن القيمة <code>true</code> للخاصيّة <code>aria-expanded</code> إنْ كان العنصُر القابل للطيّ ظاهرًا مبدئيًّا نتيجة لاستخدام الصنف <code>show</code>. يبدّل المُلحَق قيمة الخاصيّة تلقائيًّا في عنصُر التحكّم اعتمادًا على ما إذا كان العنصُر القابل للطيّ مُظهَرًا أم مخفيًّا (عن طريق [[JavaScript]] أو عندما يستخدم الزائر عنصُر تحكّم آخر مربوطًا بنفس العنصُر القابل للطيّ). إنْ لم يكن عنصُر التحكم زرًّا (<code>[[HTML/button|<button>]]</code>) فتجب إضافة الخاصيّة <code>role="button"‎</code> إليه.


تجب إضافة خاصيّة <code>aria-controls</code> تحتوي معرِّف العنصُر القابل للطيّ إلى عنصُر التحكّم إنْ كان يستهدف عنصُرًا واحدًا قابلًا للطيّ (مثلًا عندما تشير الخاصيّة <code>data-target</code> إلى معرِّف (<code>id</code>)). تستخدم قارئات الشاشة الحديثة والتقنيّات المساعدة المشابهة لها هذه الخاصيّة لتوفير اختصارات إضافيّة للمستخدمين للتنقّل إلى العنصُر القابل للطيّ مباشرة.
تجب إضافة خاصيّة <code>aria-controls</code> تحتوي معرِّف العنصُر القابل للطيّ إلى عنصُر التحكّم إنْ كان يستهدف عنصُرًا واحدًا قابلًا للطيّ (مثلًا عندما تشير الخاصيّة <code>data-target</code> إلى معرِّف [<code>id</code>]). تستخدم قارئات الشاشة الحديثة والتقنيّات المساعدة المشابهة لها هذه الخاصيّة لتوفير اختصارات إضافيّة للمستخدمين للتنقّل إلى العنصُر القابل للطيّ مباشرة.


يُرجى ملاحظة أنّ إصدارات Bootstrap حاليًّا لا تغطّي التفاعلات المختلفة مع لوحة المفاتيح المشروحة ضمن [https://www.w3.org/TR/wai-aria-practices-1.1/#accordion فقرة معيار WAI-ARIA الخاصّة بتأثير الأكورديون]؛ لذا ستحتاج لتضمين هذه التفاعلات المختلفة بنفسك عن طريق شفرة JavaScript مُخصَّصة.
يُرجى ملاحظة أنّ إصدارات Bootstrap حاليًّا لا تغطّي التفاعلات المختلفة مع لوحة المفاتيح المشروحة ضمن [https://www.w3.org/TR/wai-aria-practices-1.1/#accordion فقرة معيار WAI-ARIA الخاصّة بتأثير الأكورديون]؛ لذا ستحتاج لتضمين هذه التفاعلات المختلفة بنفسك عن طريق شفرة JavaScript مُخصَّصة.
سطر 119: سطر 124:
توجد هذه الأصناف ضمن الملفّ <code>‎_transitions.scss</code>.
توجد هذه الأصناف ضمن الملفّ <code>‎_transitions.scss</code>.


=== خاصيّات البيانات Data attributes ===
=== خاصيّات البيانات (Data attributes) ===
أضف الخاصيّة<code>data-toggle="collapse"‎</code> و <code>data-target</code> إلى العنصُر ليُسند إليه تلقائيًّا التحكّم في عنصُر قابل للطيّ أو أكثر. تستقبل الخاصيّة <code>data-target</code> محدِّد CSS لتطبيق الطيّ عليه. تأكّد من إضافة الصنف <code>collapse</code> إلى العنصُر القابل للطيّ. أضف الصنف <code>show</code> إليه إنْ كنت تريد أن يظهر مبدئيّا.
أضف الخاصيّة<code>data-toggle="collapse"‎</code> و <code>data-target</code> إلى العنصُر ليُسند إليه تلقائيًّا التحكّم في عنصُر قابل للطيّ أو أكثر. تستقبل الخاصيّة <code>data-target</code> محدِّد CSS لتطبيق الطيّ عليه. تأكّد من إضافة الصنف <code>collapse</code> إلى العنصُر القابل للطيّ. أضف الصنف <code>show</code> إليه إنْ كنت تريد أن يظهر مبدئيّا.
لإضافة إمكانية إدارة مجموعة تشبه الأكورديون إلى منطقة قابلة للطي، أضف السمة <code>data-parent="#selector"‎</code>.


=== شفرة JavaScript مُخصَّصة ===
=== شفرة JavaScript مُخصَّصة ===
سطر 128: سطر 135:


=== الخيّارات ===
=== الخيّارات ===
يمكن تمرير الخيارات عبر سمات البيانات أو جافا سكربت. بالنسبة لسمات البيانات، ألحق اسم الخيار إلى <code>data-</code>‎ كما في <code>data-parent=""‎</code>.
{| class="wikitable"
{| class="wikitable"
|الاسم
|الاسم
سطر 134: سطر 142:
|الوصف
|الوصف
|-
|-
|parent (العنصُر الأب)
|<code>parent</code> (العنصُر الأب)
|<nowiki>مُحدِّد Selector|  كائن jQuery | عنصُر DOM</nowiki>
|<nowiki>مُحدِّد Selector|  كائن jQuery | عنصُر DOM</nowiki>
|false
|<code>false</code>
|تُخفى جميع العناصر القابلة للطيّ عند إظهار العنصُر الأب - في حالة تمريره - الذي ترتبط به تلك العناصر (شبيه بتأثير الأكورديون. يعتمد على الصنف <code>card</code>). يجب أن تُعيَّن الخاصيّة على المنطقة القابلة للطيّ المستهدَفة.  
|تُخفى جميع العناصر القابلة للطيّ عند إظهار العنصُر الأب - في حالة تمريره - الذي ترتبط به تلك العناصر (شبيه بتأثير الأكورديون. يعتمد على الصنف <code>card</code>). يجب أن تُعيَّن الخاصيّة على المنطقة القابلة للطيّ المستهدَفة.  
|-
|-
|toggle (تبديل)
|<code>toggle</code> (تبديل)
|قيمة منطقيّة
|قيمة منطقيّة
|true
|<code>true</code>
|يُبدِّل حالة العنصُر القابل للطيّ.
|يُبدِّل حالة العنصُر القابل للطيّ.
|}
|}
سطر 152: سطر 160:
[[Bootstrap/javascript|راجع توثيق JavaScript في Bootstrap للمزيد من المعلومات]].
[[Bootstrap/javascript|راجع توثيق JavaScript في Bootstrap للمزيد من المعلومات]].


==== <code>‎.collapse(options)</code> ====
==== <code>‎.collapse(options)‎‎</code> ====
يجعل المحتوى قابلًا للطيّ. يقبل كائن خيّارات اختيّاري.<syntaxhighlight lang="javascript">
يجعل المحتوى قابلًا للطيّ. يقبل كائن خيّارات اختيّاري.<syntaxhighlight lang="javascript">
$('#myCollapsible').collapse({
$('#myCollapsible').collapse({
سطر 159: سطر 167:
</syntaxhighlight>
</syntaxhighlight>


==== <code>.collapse('toggle')</code> ====
==== <code>.collapse('toggle')‎‎</code> ====
يبدّل بين حالتيْ العنصُر القابل للطيّ (إخفاء أو إظهار). '''يعود إلى المستدعِي قبل أن يُظهَر أو يُخفَى العنصُر المستهدَف''' (أي قبل وقوع الحدث <code>shown.bs.collapse</code> أو <code>hidden.bs.collapse</code> )
يبدّل بين حالتيْ العنصُر القابل للطيّ (إخفاء أو إظهار). '''يعود إلى المستدعِي قبل أن يُظهَر أو يُخفَى العنصُر المستهدَف''' (أي قبل وقوع الحدث <code>shown.bs.collapse</code> أو <code>hidden.bs.collapse</code> )


==== <code>‎.collapse('show')</code> ====
==== <code>‎.collapse('show')‎‎</code> ====
يُظهر عنصُرًا قابلًا للطيّ. '''يعود إلى المستدعِي قبل أن يُظهَر العنصُر المستهدَف فعليًّا''' (أي قبل وقوع الحدث <code>shown.bs.collapse</code>).
يُظهر عنصُرًا قابلًا للطيّ. '''يعود إلى المستدعِي قبل أن يُظهَر العنصُر المستهدَف فعليًّا''' (أي قبل وقوع الحدث <code>shown.bs.collapse</code>).


==== <code>‎.collapse('hide')</code> ====
==== <code>‎.collapse('hide')‎‎</code> ====
يُخفي عنصُرًا قابلًا للطيّ. '''يعود إلى المستدعِي قبل أن يُخفَى العنصُر المستهدَف فعليًّا''' (أي قبل وقوع الحدث <code>hidden.bs.collapse</code>).
يُخفي عنصُرًا قابلًا للطيّ. '''يعود إلى المستدعِي قبل أن يُخفَى العنصُر المستهدَف فعليًّا''' (أي قبل وقوع الحدث <code>hidden.bs.collapse</code>).


==== <code>‎.collapse('dispose')</code> ====
==== <code>‎.collapse('dispose')‎‎</code> ====
يحذف قابليّة الطيّ من العنصُر.
يحذف قابليّة الطيّ من العنصُر.


سطر 196: سطر 204:


== مصادر ==
== مصادر ==
* [https://getbootstrap.com/docs/4.0/components/collapse/ صفحة Collapse في توثيق Bootstrap].
* [https://getbootstrap.com/docs/4.5/components/collapse/ صفحة Collapse في توثيق Bootstrap].
[[تصنيف:Bootstrap]]
[[تصنيف:Bootstrap|{{SUBPAGENAME}}]]
[[تصنيف:Bootstrap components]]
[[تصنيف:Bootstrap components|{{SUBPAGENAME}}]]

المراجعة الحالية بتاريخ 07:24، 14 يوليو 2020

استخدِم أصناف مكوِّن الطيّ ومُلحقات JavaScript في إطار العمل Bootstrap لإظهار المحتوى أو إخفائه حسب الحاجة.

نظرة عامة

يُستخدم مكوِّن الطيّ لإظهار وإخفاء المحتوى. تُستخدم الأزرار أو المنقورات كمنشّطات لإظهار أو إخفاء عنصر معين ترتبط به. سيؤدي تصغير عنصر إلى تحريك الارتفاع من قيمته الحالية إلى 0. ونظرًا للطريقة التي تتعامل بها CSS مع الحركات، لا يمكنك استخدام الحواشي على عنصر .collapse. استخدم بدلاً من ذلك الصنف كعنصر مغلِّف مستقل.

ملحوظة: تأثير الحركة الخاص بهذه المكونة يعتمد على استعلام الوسائط prefers-reduced-motion. راجع صفحة سهولة الوصول لمزيد من المعلومات.

مثال

تتوفّر الأصناف التاليّة لإظخار المحتوى أو إخفائه:

  • ‎.collapse تخفي المحتوى،
  • ‎.collapsing يُطبَّق هذا الصنف أثناء الانتقال بين إظهار المحتوى وإخفائه،
  • ‎.collapse.show يُظهر المحتوى.

يمكن استخدام رابط وتعيين الخاصيّة href أو زرّ بخاصيّة data-target. الخاصيّة data-toggle="collapse"‎مطلوبة في كلتا الحالتيْن.

جرّب المثال التالي.

<p>
  <a class="btn btn-primary" data-toggle="collapse" href="#collapseExample" role="button" aria-expanded="false" aria-controls="collapseExample">
    رابط بخاصيّة href
  </a>
  <button class="btn btn-primary" type="button" data-toggle="collapse" data-target="#collapseExample" aria-expanded="false" aria-controls="collapseExample">
    زرّ بخاصيّة data-target
  </button>
</p>
<div class="collapse" id="collapseExample">
  <div class="card card-body">مثال لفقرة يظهر محتواها أو يختفي بالنقر على الرابط أو الزرّ السابقيْن.
  </div>
</div>

أهداف متعدّدة

يمكن لزرّ (<button>) أو رابط () إظهار عناصر عدّة أو إخفاؤها بالإحالة إلى محدِّد jQuery في الخاصيّة href أو data-target حسب الحالة.

يمكن لأزرار أو روابط عدّة إظهار أو إخفاء نفس العنصُر إن كانت كلّها تحيل إلى خاصيّة href أو data-target في العنصُر المذكور.

<p>
  <a class="btn btn-primary" data-toggle="collapse" href="#multiCollapseExample1" role="button" aria-expanded="false" aria-controls="multiCollapseExample1">بدّل حالة العنصُر الأوّل</a>
  <button class="btn btn-primary" type="button" data-toggle="collapse" data-target="#multiCollapseExample2" aria-expanded="false" aria-controls="multiCollapseExample2">بدّل حالة العنصُر الثاني</button>
  <button class="btn btn-primary" type="button" data-toggle="collapse" data-target=".multi-collapse" aria-expanded="false" aria-controls="multiCollapseExample1 multiCollapseExample2">بدّل حالة العنصُريْن</button>
</p>
<div class="row">
  <div class="col">
    <div class="collapse multi-collapse" id="multiCollapseExample1">
      <div class="card card-body">
      مثال لفقرة يظهر محتواها (أو يختفي) عند النقر على الزرّ <strong>الأوّل</strong> أو على الزرّ <strong>الأخير</strong>. 
      </div>
    </div>
  </div>
  <div class="col">
    <div class="collapse multi-collapse" id="multiCollapseExample2">
      <div class="card card-body">
        مثال لفقرة يظهر محتواها (أو يختفي) عند النقر على الزرّ <strong>الثاني</strong> أو على الزرّ <strong>الأخير</strong>.
      </div>
    </div>
  </div>
</div>

تأثير الأكورديون

يمكن باستخدام مكوِّن البطاقات في إطار العمل Bootstrap تمديد سلوك الطيّ المبدئي لإنشاء تأثير يشبه حركة آلة الأكورديون الموسيقية.

<div class="accordion" id="accordionExample">
  <div class="card">
    <div class="card-header" id="headingOne">
      <h2 class="mb-0">
        <button class="btn btn-link btn-block text-left" type="button" data-toggle="collapse" data-target="#collapseOne" aria-expanded="true" aria-controls="collapseOne">
          العنصُر الأوّل القابل للطيّ
        </button>
      </h2>
    </div>

    <div id="collapseOne" class="collapse show" aria-labelledby="headingOne" data-parent="#accordionExample">
      <div class="card-body">
        تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
      </div>
    </div>
  </div>
  <div class="card">
    <div class="card-header" id="headingTwo">
      <h2 class="mb-0">
        <button class="btn btn-link btn-block text-left collapsed" type="button" data-toggle="collapse" data-target="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo">
          العنصُر الثاني القابل للطيّ
        </button>
      </h2>
    </div>
    <div id="collapseTwo" class="collapse" aria-labelledby="headingTwo" data-parent="#accordionExample">
      <div class="card-body">
        تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
      </div>
    </div>
  </div>
  <div class="card">
    <div class="card-header" id="headingThree">
      <h2 class="mb-0">
        <button class="btn btn-link btn-block text-left collapsed" type="button" data-toggle="collapse" data-target="#collapseThree" aria-expanded="false" aria-controls="collapseThree">
          العنصُر الثالث القابل للطيّ
        </button>
      </h2>
    </div>
    <div id="collapseThree" class="collapse" aria-labelledby="headingThree" data-parent="#accordionExample">
      <div class="card-body">        تأثير الأكورديون - يتمدّد هذا العنصُر ويظهر محتواه عند النقر على ترويسة البطاقة، في نفس الوقت تُطوى البطاقات الأخرى ويُخفى محتواها.
      </div>
    </div>
  </div>
</div>

سهولة الوصول

تأكّد من إضافة الخاصيّة aria-expanded إلى عنصُر التحكّم. تنقُل هذه الخاصيّة الحالة الراهنة للعنصُر القابل للطيّ تنقُلها إلى قارئات الشاشة والتقنيّات المساعدة المشابهة. يجب أن تكون قيمة الخاصيّة هي aria-expanded="false"‎ إنْ كان العنصُر القابل للطيّ مغلقًا مبدئيّا. عيّن القيمة true للخاصيّة aria-expanded إنْ كان العنصُر القابل للطيّ ظاهرًا مبدئيًّا نتيجة لاستخدام الصنف show. يبدّل المُلحَق قيمة الخاصيّة تلقائيًّا في عنصُر التحكّم اعتمادًا على ما إذا كان العنصُر القابل للطيّ مُظهَرًا أم مخفيًّا (عن طريق JavaScript أو عندما يستخدم الزائر عنصُر تحكّم آخر مربوطًا بنفس العنصُر القابل للطيّ). إنْ لم يكن عنصُر التحكم زرًّا (<button>) فتجب إضافة الخاصيّة role="button"‎ إليه.

تجب إضافة خاصيّة aria-controls تحتوي معرِّف العنصُر القابل للطيّ إلى عنصُر التحكّم إنْ كان يستهدف عنصُرًا واحدًا قابلًا للطيّ (مثلًا عندما تشير الخاصيّة data-target إلى معرِّف [id]). تستخدم قارئات الشاشة الحديثة والتقنيّات المساعدة المشابهة لها هذه الخاصيّة لتوفير اختصارات إضافيّة للمستخدمين للتنقّل إلى العنصُر القابل للطيّ مباشرة.

يُرجى ملاحظة أنّ إصدارات Bootstrap حاليًّا لا تغطّي التفاعلات المختلفة مع لوحة المفاتيح المشروحة ضمن فقرة معيار WAI-ARIA الخاصّة بتأثير الأكورديون؛ لذا ستحتاج لتضمين هذه التفاعلات المختلفة بنفسك عن طريق شفرة JavaScript مُخصَّصة.

استخدام مُلحَق JavaScript

يستخدم مُلحَق الطيّ في إطار العمل Bootstrap بضعة أصناف للتعامل مع الانتقال بين حالة الطيّ (الإخفاء) والسدل (الإظهار):

  • ‎.collapse يخفي المحتوى،
  • ‎.collapse.show يظهر المحتوى،
  • ‎.collapsing يُضاف هذا الصنف عند بدء الانتقال ويُحذَف بعد اكتماله.

توجد هذه الأصناف ضمن الملفّ ‎_transitions.scss.

خاصيّات البيانات (Data attributes)

أضف الخاصيّةdata-toggle="collapse"‎ و data-target إلى العنصُر ليُسند إليه تلقائيًّا التحكّم في عنصُر قابل للطيّ أو أكثر. تستقبل الخاصيّة data-target محدِّد CSS لتطبيق الطيّ عليه. تأكّد من إضافة الصنف collapse إلى العنصُر القابل للطيّ. أضف الصنف show إليه إنْ كنت تريد أن يظهر مبدئيّا.

لإضافة إمكانية إدارة مجموعة تشبه الأكورديون إلى منطقة قابلة للطي، أضف السمة data-parent="#selector"‎.

شفرة JavaScript مُخصَّصة

يُفعَّل تأثير الطيّ يدويًّا على النحو التالي:

$('.collapse').collapse();

الخيّارات

يمكن تمرير الخيارات عبر سمات البيانات أو جافا سكربت. بالنسبة لسمات البيانات، ألحق اسم الخيار إلى data-‎ كما في data-parent=""‎.

الاسم النوع القيمة المبدئيّة الوصف
parent (العنصُر الأب) مُحدِّد Selector| كائن jQuery | عنصُر DOM false تُخفى جميع العناصر القابلة للطيّ عند إظهار العنصُر الأب - في حالة تمريره - الذي ترتبط به تلك العناصر (شبيه بتأثير الأكورديون. يعتمد على الصنف card). يجب أن تُعيَّن الخاصيّة على المنطقة القابلة للطيّ المستهدَفة.
toggle (تبديل) قيمة منطقيّة true يُبدِّل حالة العنصُر القابل للطيّ.

التوابع

تنبيه: التوابع غير المتزامنة والانتقالات

توابع واجهة التطبيقات جميعها غير متزامنة وتشغّل انتقالا. تعود هذه التوابع لشفرة الاستدعاء مباشرةً بعد بدء الانتقال، لكن قبل أن ينتهي. علاوةً على ذلك، يُتجاهل استدعاء تابع على مكوِّن في طور الانتقال.

راجع توثيق JavaScript في Bootstrap للمزيد من المعلومات.

‎.collapse(options)‎‎

يجعل المحتوى قابلًا للطيّ. يقبل كائن خيّارات اختيّاري.

$('#myCollapsible').collapse({
  toggle: false
})

.collapse('toggle')‎‎

يبدّل بين حالتيْ العنصُر القابل للطيّ (إخفاء أو إظهار). يعود إلى المستدعِي قبل أن يُظهَر أو يُخفَى العنصُر المستهدَف (أي قبل وقوع الحدث shown.bs.collapse أو hidden.bs.collapse )

‎.collapse('show')‎‎

يُظهر عنصُرًا قابلًا للطيّ. يعود إلى المستدعِي قبل أن يُظهَر العنصُر المستهدَف فعليًّا (أي قبل وقوع الحدث shown.bs.collapse).

‎.collapse('hide')‎‎

يُخفي عنصُرًا قابلًا للطيّ. يعود إلى المستدعِي قبل أن يُخفَى العنصُر المستهدَف فعليًّا (أي قبل وقوع الحدث hidden.bs.collapse).

‎.collapse('dispose')‎‎

يحذف قابليّة الطيّ من العنصُر.

الأحداث

يعرض الصنف collapse في إطار العمل Bootstrap بضعة أحداث للتعامل مع وظيفة الطيّ.

نوع الحدث الوصف
show.bs.collapse ينطلق هذا الحدث مباشرةً بعد استدعاء التابع show.
shown.bs.collapse ينطلق هذا الحدث عندما يصبح العنصُر القابل للطيّ ظاهرًا للمستخدم (سينتظر حتى اكتمال انتقالات CSS).
hide.bs.collapse ينطلق هذا الحدث مباشرةً بعد استدعاء التابع hide.
hidden.bs.collapse ينطلق هذا الحدث عندما يصبح العنصُر القابل للطيّ مخفيًّا عن المستخدم (سينتظر حتى اكتمال انتقالات CSS).
$('#myCollapsible').on('hidden.bs.collapse', function () {
  // افعل شيئا …
})

مصادر