Ich habe nie ein Listview, aber ich habe nicht in einem Gridview-Gruppierung. Sie können versuchen, dies zu einem ListView zu portieren, wenn Sie möchten:
Protected Overrides Sub Render(ByVal writer As System.Web.UI.HtmlTextWriter)
Dim tblGrid As Table = Me.GridView1.Controls(0)
Dim strLastCat As String = "@"
Dim row As GridViewRow
For Each row In GridView1.Rows
Dim intRealIndex As Integer = tblGrid.Rows.GetRowIndex(row)
Dim strCat As String = Me.GridView1.DataKeys(row.RowIndex).Value
If strLastCat <> strCat Then
Dim rowHeader As New GridViewRow(intRealIndex, intRealIndex, DataControlRowType.Separator, DataControlRowState.Normal)
Dim newCell As New TableCell
newCell.ColumnSpan = Me.GridView1.Columns.Count
newCell.BackColor = System.Drawing.Color.FromArgb(61, 138, 20)
newCell.ForeColor = System.Drawing.Color.FromArgb(255, 255, 255)
newCell.Font.Bold = True
newCell.Font.Size = New FontUnit(FontSize.Larger)
newCell.Text = strCat
rowHeader.Cells.Add(newCell)
tblGrid.Controls.AddAt(intRealIndex, rowHeader)
strLastCat = strCat
End If
Next
MyBase.Render(writer)
End Sub
Der Code erstellt Header jeder Kategorie. Die endgültige Version kann hier angesehen werden: http://www.truedietreviews.com/diet-reviews/
Ich war unsicher mit Linq zu SQL, aber sobald ich die Beziehungen zum dbml hinzugefügt, Es funktionierte wie ein Charme. Vielen Dank. – kevindaub
Die Site ist offline, aber die Wayback-Maschine läuft wieder durch. http://web.archive.org/web/20101125093922/http://mattberseth.com/blog/2008/01/building_a_grouping_grid_with.html – atjoedonahue