Аз съм начинаещ в JavaScript и абсолютен начинаещ в Twitter Bootstrap. Имам повтарящи се редове в таблица, всеки от които изисква падащ акордеон, за да разкрие допълнителна информация в нова таблица.
Имам това работещо, но искам да имам анимирани шеврони нагоре и надолу, за да покажат ясно кога акордеонът на ред на основната маса е свит или разширен. Проблемът ми е, че не знам как да реферирам глификоните на всеки ред отделно (по име/идентификатор): в момента всички глификони се променят в унисон.
Моят код е даден по-долу и в JSFiddle тук: http://jsfiddle.net/leComte/7T2p3/2/. Ако някой може да забележи други явни несъответствия или лоша практика на кодиране, моля, предупредете ме и за това! :-)
<div id="OrderPackages">
<table id="tableSearchResults" class="table table-hover table-striped table-condensed">
<thead>
<tr>
<th>Package ID</th>
<th>Quantity</th>
<th></th>
</tr>
</thead>
<tbody>
<tr class="accordion-toggle" data-toggle="collapse" data-parent="#OrderPackages" data-target=".packageDetails1">
<td>123456</td>
<td>3</td>
<td><i class="indicator glyphicon glyphicon-chevron-up pull-right"></i>
</td>
</tr>
<tr>
<td colspan="3" class="hiddenRow">
<div class="accordion-body collapse packageDetails1" id="accordion1">
<table>
<tr>
<td>Revealed item 1</td>
</tr>
<tr>
<td>Revealed item 2</td>
</tr>
</table>
</div>
</td>
</tr>
<tr class="accordion-toggle" data-toggle="collapse" data-parent="#OrderPackages" data-target=".packageDetails2">
<td>654321</td>
<td>2</td>
<td><i class="indicator glyphicon glyphicon-chevron-up pull-right"></i>
</td>
</tr>
<tr>
<td colspan="3" class="hiddenRow">
<div class="accordion-body collapse packageDetails2" id="accordion2">
<table>
<tr>
<td>Revealed item 1</td>
</tr>
<tr>
<td>Revealed item 2</td>
</tr>
<tr>
<td>Revealed item 3</td>
</tr>
</table>
</div>
</td>
</tr>
<tr></tr>
</tbody>
</table>
</div>
$('#accordion1').on('shown.bs.collapse', function () {
$("i.indicator").removeClass("glyphicon-chevron-up").addClass("glyphicon-chevron-down");
});
$('#accordion1').on('hidden.bs.collapse', function () {
$("i.indicator").removeClass("glyphicon-chevron-down").addClass("glyphicon-chevron-up");
});
$('#accordion2').on('shown.bs.collapse', function () {
$("i.indicator").removeClass("glyphicon-chevron-up").addClass("glyphicon-chevron-down");
});
$('#accordion2').on('hidden.bs.collapse', function () {
$("i.indicator").removeClass("glyphicon-chevron-down").addClass("glyphicon-chevron-up");
});