Folgendes Szenario: Beim Wechseln der Registerkarte wird hierzu das "Click"-Ereignis ausgelöst. Über den Parameter PreviousTab kann die vorige Registerkarte abgefragt werden: Private Sub SSTab1_Click(PreviousTab As Integer) If PreviousTab = 0 Then ' Prüfen, ob alle zwingenden Angaben der ' 1. Registerkarte gemacht wurden ' ' In diesem Beispiel darf die TextBox "txtName" ' nicht leer sein If Len(txtName.Text) = 0 Then ' Falls nicht, Wechsel der Registerkare unterbinden ' und 1. Registerkarte wieder aktivieren SSTab1.Tab = 0 MsgBox "Bitte geben Sie zunächst Ihren Namen ein!" End If ElseIf PreviousTab = 1 Then ' Prüfen, ob alle zwingenden Angaben der ' 2. Registerkarte gemacht wurden ' ' In diesem Beispiel darf die TextBox "txtEMail" ' nicht leer sein If Len(txtEMail.Text) = 0 Then ' Falls nicht, Wechsel der Registerkare unterbinden ' und 2. Registerkarte wieder aktivieren SSTab1.Tab = 1 MsgBox "Bitte EMail-Adresse eingeben!" End If End If End Sub Viele User würden obigen Code für "richtig" finden, staunen aber nicht schlecht, wenn Sie den Code ausführen. Durch die Anweisung SSTab.Tab = ... wird autom. wieder das Click-Ereignis ausgelöst, wobei der Parameter "PreviousTab" diesmal schon den Wert der neuen Registerkarte besitzt. Der Code im Click-Ereignis wird daher wieder ausgeführt, was zu einer Endlosschleife führt! Mit nachfolgender Änderung kann man die Endlosschleife unterbinden und den Wechsel der Registerkarte bei fehlenden Angaben korrekt unterbinden: Private Sub SSTab1_Click(PreviousTab As Integer) Static bWorking As Boolean If bWorking Then Exit Sub bWorking = True If PreviousTab = 0 Then ' Prüfen, ob alle zwingenden Angaben der ' 1. Registerkarte gemacht wurden ' ' In diesem Beispiel darf die TextBox "txtName" ' nicht leer sein If Len(txtName.Text) = 0 Then ' Falls nicht, Wechsel der Registerkare unterbinden ' und 1. Registerkarte wieder aktivieren SSTab1.Tab = 0 MsgBox "Bitte geben Sie zunächst Ihren Namen ein!" End If ElseIf PreviousTab = 1 Then ' Prüfen, ob alle zwingenden Angaben der ' 2. Registerkarte gemacht wurden ' ' In diesem Beispiel darf die TextBox "txtEMail" ' nicht leer sein If Len(txtEMail.Text) = 0 Then ' Falls nicht, Wechsel der Registerkare unterbinden ' und 2. Registerkarte wieder aktivieren SSTab1.Tab = 1 MsgBox "Bitte EMail-Adresse eingeben!" End If End If bWorking = False End Sub Dieser Tipp wurde bereits 10.046 mal aufgerufen.
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv (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. |
sevZIP40 Pro DLL ![]() Zippen und Unzippen wie die Profis! Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. Tipp des Monats Heinz Prelle Datei-Mehrfachauswahl an eine ListBox übergeben Dieser Tipp zeigt, wie Sie über den Windows-CommonDialog eine Mehrfach-Dateiauswal realisieren... TOP Entwickler-Paket ![]() TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1866.50 EUR... |
||||||||||||||||
|
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. |
|||||||||||||||||


SSTab: Registerkarte wechsle nicht!


