[英]Getting the Header Rows Count of Multi Column Header in WebDataGrid, Infragistics
我在WebDataGrid中為項目使用多標題列(GroupFields)。 有沒有一種方法來獲取標題行的深度,即。 標頭行計數。 考慮深度大於二,即。 子字段也可以是一個groupfield並包含多個子字段。 因此,有一種方法可以動態地計算總標頭行數。 我嘗試了遞歸,但是由於循環在遞歸fn之后不會停止並繼續使用舊計數而陷入困境,所以被卡住了。 這是我的代碼,非常感謝您的幫助。
protected void MultiColheader(object sender, EventArgs e)
{
List<GridField> unhiddenColumns = (from GridField p in LookupGrid.Columns
where !p.Hidden
select p).ToList<GridField>();
int count = 0;
int[] ar = new int[unhiddenColumns.Count];
for (int i = 0; i < unhiddenColumns.Count; i++)
{
if (LookupGrid.Columns[i].GetType() == typeof(GroupField))
{
count = 1;
GroupField groupfield = (GroupField)LookupGrid.Columns[i];
ar[i] = _HrowCount(groupfield, count);
}
count = 0;
}
Response.Write(ar.Max());
}
public int _HrowCount(GroupField gf, int count)
{
for (int k = 0; k < gf.Columns.Count; k++)
{
if (gf.Columns[k].GetType() == typeof(GroupField))
{
GroupField gpf = (GroupField)gf.Columns[k];
count = count + 1;
_HrowCount(gpf, count);
}
}
return count;
}
您可以使用類似於以下內容的遞歸函數:
private int RecursiveIteration(GridFieldCollection field)
{
int count = 0;
for (int i = 0; i < field.Count ; i++)
{
if (field[i].GetType() == typeof(GroupField))
{
count += RecursiveIteration((field[i] as GroupField).Columns);
}
count++;
}
return count;
}
該函數將列集合作為參數,因此為了獲得總列數:
int colCount = RecursiveIteration(WebDataGrid1.Columns);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.