Die zwei Funktionen zum Clonen eines DatagridView gestatten das 1:1-Kopieren der Werte als auch der Formate. Hier die Funktionen: ''' <summary> ''' Clonen eines DatagridView (Clone ist ungebunden, spiegelt nur die Daten der Source) ''' </summary> ''' <param name="theDGVsrc">das Quell-DatagridView</param> ''' <param name="theDGVdest">das Ziel-DatagridView</param> Public Sub CloneDGV(ByVal theDGVsrc As DataGridView, ByVal theDGVdest As DataGridView) Dim dr As DataGridViewRow, i As Short With theDGVdest ' initialisieren des Ziel-DGV .RowCount = 1 .ColumnCount = theDGVsrc.ColumnCount ' zunächst die Spaltenstile clonen For i = 0 To theDGVsrc.ColumnCount - 1 .Columns(i).HeaderText = theDGVsrc.Columns(i).HeaderText .Columns(i).DefaultCellStyle = theDGVsrc.Columns(i).DefaultCellStyle.Clone Next ' jetzt alle Zeilen clonen For i = 0 To theDGVsrc.RowCount - 1 ' geclonte Zeile erzeugen und dem Ziel-DGV zufügen dr = CloneDGVRowWithValues(theDGVsrc.Rows(i)) .Rows.Add(dr) Next End With End Sub ''' <summary> ''' Clonen einer DatagridView-Row; ausschließlich Werte ''' </summary> ''' <param name="theRow">eine Zeile des DatagridView</param> ''' <returns>geclonte Zeile</returns> Public Function CloneDGVRowWithValues(ByVal theRow As DataGridViewRow) As DataGridViewRow CloneDGVRowWithValues = CType(theRow.Clone(), DataGridViewRow) ' die Werte aus den Zellen der Quell-Zeile clonen For i As Short = 0 To theRow.Cells.Count - 1 CloneDGVRowWithValues.Cells(i).Value = theRow.Cells(i).Value Next Return CloneDGVRowWithValues End Function Allerdings muss man noch dazu sagen, dass DGV-globale Eigenschaften von diesen Funktionen nicht kopiert werden. Damit meine ich beispielsweise in etwa solche Eigenschaften wie: With dgv .AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells .AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells .AllowUserToOrderColumns = False .AllowUserToDeleteRows = False .AllowUserToAddRows = False .RowHeadersDefaultCellStyle.Font = .DefaultCellStyle.Font .DefaultCellStyle.SelectionBackColor = .DefaultCellStyle.BackColor .DefaultCellStyle.SelectionForeColor = Color.Black For Each c As DataGridViewColumn In .Columns c.SortMode = DataGridViewColumnSortMode.NotSortable Next .ReadOnly = True End With o.a. Die kann man so duplizieren: myDestDGV = mySrcDGV und danach die obigen Funktionen anwenden. Dieser Tipp wurde bereits 15.151 mal aufgerufen.
Anzeige
![]() ![]() ![]() Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
vb@rchiv CD Vol.6 ![]() ![]() Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats Neu! sevDTA 3.0 Pro ![]() SEPA mit Kontonummernprüfung Erstellen von SEPA-Dateien mit integriertem BIC-Verzeichnis und Konto- nummern-Prüfverfahren, so dass ungültige Bankdaten bereits im Vorfeld ermittelt werden können. |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |