簡體   English   中英

在WebDataGrid中獲取Infragistics中多列標題的標題行計數

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM