在这里扩展答案: Bootstrap 3 collapse change chevron icon on click
我正在尝试在表格行扩展时将字形更改为up,但它不起作用,而且我对js的了解非常有限。我试过接受trante的回答
$('.chevron_toggleable').on('click', function() {
$(this).toggleClass('glyphicon-chevron-down glyphicon-chevron-up');
});
<span class="chevron_toggleable glyphicon glyphicon-chevron-down"></span>
并将其修改如下:
$('.accordion-toggle').on('click', function() {
$(this).closest("td").find("chevron_toggleable").toggleClass('glyphicon-chevron-down glyphicon-chevron-up');
});
其中accordion-toggle是可以进行折叠的行的类名。当行按原样折叠时,图标不会改变。我已经尝试将“td”更改为“table”,“tr”等,但它似乎无法正常工作
更新:对于APAD:
我正在使用php生成整个表,但这是相关的代码:
if (mysqli_num_rows($result)) {
echo '<table id="dasTable" cellpadding="0" cellspacing="0" class="table table-responsive table-hover table-bordered tablesorter">';
echo '<thead>';
echo '<tr><th>Service ID</th><th>Assigned Namespace</th><th>DAS Station</th><th>Ingest Completed</th><th>Currently Ingesting</th><th>Offsite going to DAS</th><th>Mounted</th></tr></thead>';
echo '<tbody>';
// Generate rows from current das information
while ($row2 = mysqli_fetch_row($result)) {
// Format cell background based on content
$sidvalue = $row2[0];
$station = $row2[1];
$used = $row2[2];
$attacheddate = $row2[3];
$starteddate = $row2[4];
$ingestcomplete = $row2[5];
$ingesting = $row2[6];
$updating = $row2[7];
$mounted = $row2[8];
$totaljobs = $row2[9];
$remainingjobs = $row2[10];
$assigned = $row2[11];
echo '<tr class="bg-info accordion-toggle" data-toggle="collapse" id="', $sidvalue, '" data-target=".', $sidvalue, '">';
echo '<td><span class="glyphicon glyphicon-plus"></span> ', $sidvalue, '</td>';
echo '<td>', $assigned, '</td>';
echo '<td>', $station, '</td>';
echo '<td>', $ingestcomplete, '</td>';
if ($ingesting == 'GREEN') {
echo '<td class="success">YES</td>';
} else {
if ($ingestcomplete != 'NO') {
echo '<td class="success">NO</td>';
} else {
echo '<td class="danger">NO</td>';
}
}
if ($updating == 'GREEN') {
echo '<td class="success">NO</td>';
} else {
echo '<td class="danger">YES</td>';
}
if ($mounted == 'GREEN') {
echo '<td class="success">YES</td>';
} else {
if ($ingestcomplete != 'NO') {
echo '<td class="success">NO</td>';
} else {
echo '<td class="danger">NO</td>';
}
}
echo '</tr>';
// create the sub row
echo '<tr class="expand-child collapse ', $sidvalue, '">';
echo '<td class="h4" colspan="3"><b>Attached Date:</b> ', $attacheddate, '</td>';
echo '<td class="h4" colspan="4"><span class="glyphicon glyphicon-hdd"></span> ', $used, ' Bytes</td>';
echo '</tr>';
echo '<tr class="expand-child collapse ', $sidvalue, '">';
echo '<td class="h4" colspan="3"><b>Ingest Start Date:</b> ', $starteddate, '</td>';
echo '<td class="h4" colspan="4">';
echo '<div class="progress">';
if ($remainingjobs == 0) {
echo '<div class="progress-bar progress-bar-success progress-bar-striped active" role="progressbar" aria-valuenow="50" aria-valuemin="0" aria-valuemax="100" style="width:100%">Last Job</div>';
} else {
$jobsdone = $totaljobs - $remainingjobs;
$percentdone = round($jobsdone / $totaljobs *100, 1);
echo '<div class="progress-bar progress-bar-info progress-bar-striped active" role="progressbar" aria-valuenow="50" aria-valuemin="0" aria-valuemax="100" style="width:', $percentdone, '%">', $jobsdone, '/', $totaljobs, ' (', $percentdone, '%)</div>';
}
echo '</div>';
echo '</td>';
echo '</tr>';
}
echo '</tbody>';
echo '</table><br />';
}
这将生成一个如下所示的表:
当用户点击该行的任意位置时,它会展开以显示以下内容:
答案 0 :(得分:2)
这可以帮到你:
$('.a').on('click', function() {
$(this).find('span').closest('.chevron_toggleable').toggleClass('glyphicon-chevron-down glyphicon-chevron-up');
});
考虑这个html:
<div class="a">
<span class="chevron_toggleable glyphicon glyphicon-chevron-down"></span>
</div>
<div class="a">
<span class="chevron_toggleable glyphicon glyphicon-chevron-down"></span>
</div>
<div class="a">
<span class="chevron_toggleable glyphicon glyphicon-chevron-down"></span>
</div>
<div class="a">
<span class="chevron_toggleable glyphicon glyphicon-chevron-down"></span>
</div>
答案 1 :(得分:0)
问题是你正在使用public function saveRegister()
{
$rules = array(
'name' => 'required',
'description' => 'required',
'fullname' => 'required',
'email' => 'required',
'password' => 'required',
'state' => 'required',
'city' => 'required',
'photo' => 'required',
'photo' => 'image|max:3000000',
);
$val = \Validator::make(\Input::all(), $rules);
if($validar->fails()){
return redirect('register')->withErrors($val);
} else {
$user = new User(array(
'name' => \Input::get('name'),
'description' => \Input::get('description'),
'fullname' => \Input::get('fullname'),
'email' => \Input::get('email'),
'city_id' => \Input::get('city'),
));
$user->timestamps = false;
$user->save();
return redirect('register')->with('message', 'User saved!');
}
}
,它会测试元素本身,然后遍历向上 DOM找到最接近的元素 - 该函数不会查看你的{{1}孩子们。请改用.closest
。根据您的文档结构,下面的内容可能无法正常工作。但是,如果您可以编写一个找到正确tr
的选择器,只需将其与.find
中的当前选择器进行交换。
td