vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
NEU! sevCoolbar 3.0 - Professionelle Toolbars im modernen Design!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   RSS-Feeds  | Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2021
 
zurück
Rubrik: Controls · ListBox   |   VB-Versionen: VB4, VB5, VB606.07.07
ListBox schneller füllen

Durch kurzzeitiges "Unsichtbarmachen" der ListBox erfolgt das Füllen der ListBox bei größeren Datenmengen um ein vielfaches schneller.

Autor:   Dieter OtterBewertung:     [ Jetzt bewerten ]Views:  11.837 
www.tools4vb.deSystem:  Win9x, WinNT, Win2k, WinXP, Vista, Win7, Win8, Win10 Beispielprojekt auf CD 

Immer wenn eine ListBox mit größeren Datenmengen gefüllt werden soll, empfiehlt sich die Aktualisierung der ListBox auszuschalten. Das hat den Vorteil, dass das Control nicht flackert, während die Einträge hinzugefügt werden und der gesamte Vorgang auch noch um ein Vielfaches schneller ausgeführt wird.

Am einfachsten lässt sich die Aktualisierung ausschalten, indem die Visible-Eigenschaft auf False gesetzt wird.

Anhand eines kleines Beispielprojekts haben wir einmal die Zeiten mit und ohne "Visible = False" gemessen. Die ListBox wurde hierbei mit 25.000 Einträgen gefüllt. Ohne das Ausschalten der Visible-Eigenschaft benötigte der Code auf unserem System 4,6 Sekunden. Durch das Abschalten der Aktualisierung brauchte der gesamte Vorgang nur noch 1.3 Sekunden.

Beispiel
Erstellen Sie ein neues Projekt, platzieren auf die Form1 ein ListBox-Control, ein CheckBox-Control, sowie einen Command-Button. Fügen Sie nachfolgenden Code in den Codeteil der Form ein:

Private Sub Form1_Load()
  ' Controls beschriften
  Check1.Caption = "Aktualisierung abschalten"
  Command1.Text = "Start"
End Sub
 
Private Sub Command1_Click()
  Dim nTime As Single
  Dim i As Long
 
  ' Startzeit
  nTime = Timer
 
  With List1
    ' Aktualisierung ausschalten
    If Check1.Value Then .Visible = False
 
    ' ListBox füllen
    .Clear
    For i = 1 To 25000
      .AddItem "Eintrag " & CStr(i)
    Next i
 
    ' Aktualisierung wieder einschalten
    If Check1.Value Then .Visible = True
  End With
 
  ' Benötigte Zeit anzeigen
  Me.Caption = Format$(Timer - nTime, "0.#### Sek.")
End Sub

Dieser Tipp wurde bereits 11.837 mal aufgerufen.

Voriger Tipp   |   Zufälliger Tipp   |   Nächster Tipp

Über diesen Tipp im Forum diskutieren
Haben Sie Fragen oder Anregungen zu diesem Tipp, können Sie gerne mit anderen darüber in unserem Forum diskutieren.

Neue Diskussion eröffnen

nach obenzurück


Anzeige

Kauftipp Unser Dauerbrenner!Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv  Vol.6
(einschl. Beispielprojekt!)

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.
 
   

Druckansicht Druckansicht Copyright ©2000-2021 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
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.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel