我正在尝试强制javascript在展开其中一行时折叠所有其他行,我只想一次扩展一行。我是javascript的新手,所以我希望有人能指出我正确的方向。
我查看了我找到的这个示例,但由于某种原因我的代码没有折叠行: Expand/Collapse all DetailViews in a grid
我不应该像在javascript中一样崩溃索引吗?
MVC Razor中的Telerik Grid视图:
<div>
@(Html.Telerik().Grid<RentableUnit>()
.Name("RentableUnits")
.Columns(columns =>
{
columns.Bound(e => e.UnitID).Hidden();
columns.Bound(e => e.Name).Width(800);
columns.Bound(e => e.IsExpanded).Hidden();
})
.ClientEvents(events => events.OnRowDataBound("employees_onRowDataBound")
.OnDetailViewExpand("unit_onDetailViewExpand")
.OnDetailViewCollapse("unit_onDetailViewCollapse")
.OnDetailViewExpand("toggleDetail")
)
.DetailView(details => details.ClientTemplate(
//stuff in template
)
.DataBinding(dataBinding => dataBinding.Ajax().Select("RentableUnits", "Home"))
.Sortable()
)
</div>
我的Javascript:
function toggleDetail(e) {
var grid = $(this).data('tGrid');
grid.$rows().each(function (index) {
//TODO: exclude the expanded row
grid.collapseRow(index); //doesn´t collapse!
});
}
答案 0 :(得分:3)
这样可以解决问题:
function toggleDetail(e){
var grid = $(this).data('tGrid');
grid.$rows().not(e.masterRow).each(function(index, row){
grid.collapseRow(row);
});
}
请注意,您为OnDetailViewExpand事件定义了2个处理程序。