Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Access > VBA Access
VBA Access Le forum pour les questions relatives au code VBA sous Access, et à son environnement de développement VBE.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 18/05/2011, 15h06   #1
Nom
Membre habitué
 
Inscription : octobre 2005
Messages : 528
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 528
Points : 143
Points : 143
Par défaut OpenArgs Null (ou passage d'objet entre formulaire)

Bonjour à tous,
J'ai un petit souci avec le passage d'informations entre formulaires
J'ai donc 2 formulaires (form1 et form2). Dans le premier formulaire, je fais un traitement et j'ai besoin du résultat de ce traitement dans le formulaire 2.
Après quelque recherche, j'ai vu que la méthode OpenForm acceptait un paramètre args qui pouvait résoudre mon problème (je concatène les informations entre elles et je split dans le 2nd formulaire)

Néanmoins, lorsque j'essaie de récupérer cette information dans le second formulaire, il m'indique null

J'ai lu sur ce forum qu'il était préférable de mettre uniquement des variables pour le OpenForm (chose que j'ai faite) mais cela ne résous pas le problème

Bref, j'aimerai que vous m'aidiez soit à bien faire fonctionner ce OpenArgs soit en me proposant une autre méthode

Pour info, voici mon code actuel (que j'ai simplifié au maximum mais qui ne marche pas)

Dans le permier formulaire :
Code vba :
1
2
3
4
5
6
Private Sub Bouton1_Click()
    Dim args As String
    args = "test"
    stDocName = "form2"
    DoCmd.OpenForm stDocName, , , , , , args
End Sub

et dans le second :
Code vba :
1
2
3
4
Private Sub Form_Open(Cancel As Integer)
    Dim args As String
    args = Me.OpenArgs
End Sub
__________________
Le savoir est une arme alors soyons armés
Nom est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/05/2011, 15h29   #2
Rédacteur/Modérateur
 
Avatar de jpcheck
 
Jean-Philippe ANDRÉ
Inscription : juillet 2007
Messages : 7 863
Détails du profil
Informations personnelles :
Nom : Jean-Philippe ANDRÉ
Âge : 28
Localisation : France

Informations forums :
Inscription : juillet 2007
Messages : 7 863
Points : 10 737
Points : 10 737
Envoyer un message via MSN à jpcheck
salut,
chez moi le simple
Code :
DoCmd.OpenForm "form1", , , , , , "pioupiou"
avec
Code :
1
2
3
Private Sub Form_Load()
Debug.Print Me.OpenArgs
End Sub
fonctionne
en mode Pas a Pas, y a-t-il une ligne qui pose probleme ?
__________________
Pas de question technique par MP, je ne réponds pas

Mon perso ? Une vraie brute

Tutos Access, Tâches planifiées et Batch,Tables de Paramètres sous Access, Excel et Batch, Tâches planifiées et Access
jpcheck est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/05/2011, 15h57   #3
Nom
Membre habitué
 
Inscription : octobre 2005
Messages : 528
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 528
Points : 143
Points : 143
J'ai relancé mon appli puis commenté et décommenté le code (sans changement donc) et maintenant ça marche

J'ai l'impression que OpenArgs n'est pas très fiable ...

il n'y aurai pas une autre solution pour "échanger" des données entre 2 formulaires ?
__________________
Le savoir est une arme alors soyons armés
Nom est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/05/2011, 16h10   #4
Rédacteur/Modérateur
 
Avatar de jpcheck
 
Jean-Philippe ANDRÉ
Inscription : juillet 2007
Messages : 7 863
Détails du profil
Informations personnelles :
Nom : Jean-Philippe ANDRÉ
Âge : 28
Localisation : France

Informations forums :
Inscription : juillet 2007
Messages : 7 863
Points : 10 737
Points : 10 737
Envoyer un message via MSN à jpcheck
Tu peux envisager le passage par une table de parametre intermediaire

http://jpcheck.developpez.com/tutori...es-initiation/
__________________
Pas de question technique par MP, je ne réponds pas

Mon perso ? Une vraie brute

Tutos Access, Tâches planifiées et Batch,Tables de Paramètres sous Access, Excel et Batch, Tâches planifiées et Access
jpcheck est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/05/2011, 16h16   #5
Nom
Membre habitué
 
Inscription : octobre 2005
Messages : 528
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 528
Points : 143
Points : 143
Comme je m’appuie sur un Treeview(du formulaire1)
J'ai décidé de faire tout le traitement dans le formulaire 2
et je récupère les infos via un Form_form1.Treeview.SelectedItem
Ça semble fonctionner. Pourvu que ça dure !
__________________
Le savoir est une arme alors soyons armés
Nom est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 14h42.


 
 
 
 
Partenaires

Hébergement Web