FAQ VB.NETConsultez toutes les FAQ
Nombre d'auteurs : 37, nombre de questions : 240, dernière mise à jour : 12 mai 2018 Ajouter une question
Cette FAQ a été réalisée pour répondre aux questions les plus fréquemment posées sur le forum Développement DotNET
Je tiens à souligner que cette FAQ ne garantit en aucun cas que les informations qu'elle contient sont correctes. Les auteurs font le maximum, mais l'erreur est humaine. Si vous trouvez une erreur, ou que vous souhaitez devenir rédacteur, lisez ceci.
Sur ce, je vous souhaite une bonne lecture.
On se sert des événements de touches. Ils se produisent lorsque le TextBox a le focus dans l'ordre suivant
- KeyDown : Une touche a été enfoncée ;
- KeyPress : Déclenché si la touche enfoncée représente un caractère. (Il n'est pas déclenché pour les touches F1, F2 par exemple) ;
- KeyUp : Une touche a été relâchée.
Voici un exemple d'utilisation :
- Créer un projet WinForm C# ;
- Ajouter deux TextBox à la form principale de votre projet ;
- Le code suivant utilise une form nommée Form1, et deux TextBox nommés textBox1 et textBox2 ;
- Toutes les touches frappées sur le textBox1 se répercutent sur textBox2 ;
- Compiler et lancer le projet, puis entrer des données dans textBox1.
Code vb.net : | Sélectionner tout |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 | 'KeyPress Handler Private Sub TextBox1_KeyPress(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyPressEventArgs) _ Handles TextBox1.KeyPress ' On affiche tous les caractères imprimables If Not Char.IsControl(e.KeyChar) Then TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.SelectionStart) + _ e.KeyChar.ToString + _ TextBox1.Text.Substring(TextBox1.SelectionStart + _ TextBox1.SelectionLength) End If End Sub ' KeyDown Handler Private Sub textBox1_KeyDown(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyEventArgs) _ Handles TextBox1.KeyDown ' Gestion Touche Back If e.KeyCode = Keys.Back AndAlso TextBox1.Text.Length > 0 Then 'Suppression sélection If TextBox1.SelectionLength > 0 Then TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.SelectionStart) + _ TextBox1.Text.Substring(TextBox1.SelectionStart + _ TextBox1.SelectionLength) ElseIf TextBox1.SelectionStart > 0 Then ' Suppression caractère précédant le curseur If TextBox1.SelectionStart = TextBox1.Text.Length Then TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.Text.Length - 1) Else TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.SelectionStart - 1) + _ TextBox1.Text.Substring(TextBox1.SelectionStart + _ TextBox1.SelectionLength) End If End If ' Touche Delete (suppr) ElseIf e.KeyCode = Keys.Delete AndAlso TextBox1.Text.Length > 0 Then ' Le curseur est en fin de chaîne If TextBox1.SelectionStart = TextBox1.Text.Length Then ' Suppression dernier caractère par Shift+Del If e.Shift Then TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.Text.Length - 1) End If Else ' On prend tous les caractères à gauche du curseur TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.SelectionStart) If Not (TextBox1.SelectionLength = 0) Then 'Suppression de la selection TextBox2.AppendText(TextBox1.Text.Substring(TextBox1.SelectionStart + TextBox1.SelectionLength)) Else ' Si la touche control est enfoncée, tous les caractères ' à droite du curseur seront supprimés. Sinon on en supprime 'un seul If Not e.Control Then TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.SelectionStart) + _ TextBox1.Text.Substring(TextBox1.SelectionStart + 1) End If End If End If ' Coller (Ctrl+V) ou (Shift+insert) ElseIf (e.Shift AndAlso e.KeyCode = Keys.Insert) OrElse (e.Control AndAlso e.KeyCode = Keys.V) Then ' Données dans presse papier Dim cpdata As IDataObject = Clipboard.GetDataObject ' Test si cpdata contient du texte If Not (cpdata Is Nothing) AndAlso cpdata.GetDataPresent(String.Empty.GetType) Then Dim data As String = cpdata.GetData(String.Empty.GetType).ToString Dim print As Boolean = False ' Gestion caractères non imprimables (comme les tabulations par exemple) For i As Integer = 0 To data.Length - 1 If Char.IsControl(data, i) AndAlso print Then data = data.Substring(0, i) Exit For ElseIf Not Char.IsControl(data, i) AndAlso Not print Then print = True End If System.Math.Min(System.Threading.Interlocked.Increment(i), i - 1) Next TextBox2.Text = TextBox1.Text.Substring(0, TextBox1.SelectionStart) + _ data + _ TextBox1.Text.Substring(TextBox1.SelectionStart + TextBox1.SelectionLength) End If End If End Sub |
On se sert de l'événement KeyPress pour intercepter les caractères entrés dans le TextBox.
La propriété Handle de la classe KeyPressEventArgs indique à l'application ce qu'il faut faire du caractère intercepté.
- Si elle vaut false, le traitement par défaut du caractère (l'affichage pour les caractères imprimables) est appliqué.
- Si elle vaut true, c'est votre code qui décide ce qu'il faut faire du caractère. Si vous ne faites rien, il ne sera pas affiché.
- Sa valeur par défaut est false.
Exemple simple
Code vb.net : | Sélectionner tout |
1 2 3 4 5 6 7 8 9 | Private Sub TextBox1_KeyPress(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyPressEventArgs) _ Handles TextBox1.KeyPress If Not Char.IsDigit(e.KeyChar) Then ' Tous les caractères non numériques ne sont pas traités sur le TextBox. e.Handled = True End If End Sub |
Si vous voulez faire un véritable contrôle TexBox numérique, vous devez en tenir compte, gérer le copier-coller CTRL+C et SHIFT+INS avec l'événement KeyDown, et aussi avec le clic droit (menu contextuel coller) sur la souris.
Il vous faut itérer les contrôles présents sur le formulaire et tester s'ils sont de type TextBox.
Code vb.net : | Sélectionner tout |
1 2 3 | For Each (Dim c As Control in Me.Controls) If (TypeOf(c) Is TextBox) Then c.Enabled = False Next |
Pour lire le contenu d'une TextBox ligne par ligne, veuillez utiliser un « $For Each » sur la propriété « $Lines » de votre TextBox.
Code vb.net : | Sélectionner tout |
1 2 3 | For Each line As String In TextBox1.Lines MsgBox(line) Next line |
Quand on rajoute du texte à un textbox multiligne avec, par exemple :
Code vb.net : | Sélectionner tout |
1 2 3 4 5 | Dim i As Integer For i = 1 To 100 TextBox1.Text = "abc" + Convert.ToString(i) + Environment.NewLine Next |
Pour y remédier, on peut utiliser ces deux lignes de code pour renvoyer le curseur à la fin et provoquer le défilement jusqu'à celui-ci.
Code vb.net : | Sélectionner tout |
1 2 | TextBox1.SelectionStart = TextBox1.TextLength TextBox1.ScrollToCaret() |
Code vb.net : | Sélectionner tout |
TextBox1.Focus();
Proposer une nouvelle réponse sur la FAQ
Ce n'est pas l'endroit pour poser des questions, allez plutôt sur le forum de la rubrique pour çaLes sources présentées sur cette page sont libres de droits et vous pouvez les utiliser à votre convenance. Par contre, la page de présentation constitue une œuvre intellectuelle protégée par les droits d'auteur. Copyright © 2024 Developpez Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon vous encourez selon la loi jusqu'à trois ans de prison et jusqu'à 300 000 € de dommages et intérêts.