Ανανέωση ιστοσελίδας

Access - Ερωτήσεις / Απαντήσεις Access + VBA... Εδώ δεν υπάρχουν όρια!

Απάντηση στο θέμα

 

Εργαλεία Θεμάτων Τρόποι εμφάνισης
  #1  
Παλιά 16-03-17, 17:25
Όνομα: Γιάννης
Έκδοση λογισμικού Office: Ms-Office 2013
Γλώσσα λογισμικού Office: Αγγλική
 
Εγγραφή: 01-10-2014
Μηνύματα: 13
Προεπιλογή VBA - Class Interface

Γεια σας παιδιά! Καταρχάς θα ήθελα να σας πω ένα μεγάλο μπράβο για την έργο που κάνετε μέσα από αυτό το Forum! Μπορεί να είναι η πρώτη μου δημοσίευση αλλά σας παρακολουθώ αρκετό καιρό.

Η επαφή μου τόσο με την Access όσο και την VBA έγινε πριν μερικούς μήνες. Επίσης δεν γνωρίζω καμία άλλη γλώσσα προγραμματισμού ούτε κάποιο άλλο πρόγραμμα βάσεις δεδομένων. Έτσι ζητώ συγγνώμη για την ορολογία που θα χρησιμοποιήσω, η οποία ξέρω ότι με κάνει δύσκολα κατανοητό.

Στο θέμα τώρα. Προσπαθώντας να υλοποιήσω το interface μιας κλάσης έχω το εξής πρόβλημα:
Όταν η interface Class περιλαμβάνει μέθοδο που έχει για παράμετρο, μεταβλητή τύπου access.Form, τότε όταν πάω να υλοποιήσω το interface σε μια άλλη Κλάση λαμβάνω μήνυμα λάθους ”User-defined type not defined”. Το μήνυμα εμφανίζεται μέσα στον VBA Editor αμέσως μόλις επιλέξω από τον Object drop-down list την interface Class και παράλληλα από-επιλέγεται από τον Object drop-down list η κλάση που μόλις είχα επιλέξει. Στην ουσία δεν με αφήνει να επιλέξω την interface Class από τον Object drop-down list, ώστε έπειτα να εισάγω τις μεθόδους και τις ιδιότητες που την υλοποιούν.

Παράδειγμα
Class Module: clsIMyObject - Interface Class
Κώδικας:
'----------------------------------------
' clsIMyObject - Interface Class
'----------------------------------------
Option Compare Database
Option Explicit

Public Sub method1(frm As Access.Form)
End Sub
Class Module: clsMyObject1 - Η κλάση που υλοποιεί την clsIMyObject
Κώδικας:
'----------------------------------------
' clsMyObject1 - Implements clsIMyObject
'----------------------------------------
Option Compare Database
Option Explicit

Implements clsIMyObject

'1) Mόλις επιλέξω από τον Object drop-down list την clsIMyObject λαμβάνω το Error  ”User-defined type not defined”
'2) Αν όμως με το πληκτρολόγιο γράψω:
'        Private Sub clsIMyObject_method1(frm As Form)
'           'some code'
'        End Sub
'  τότε δεν έχω κανένα πρόβλημα, αναγνωρίζεται κανονικά ως υλοποίηση της Interface Class!!!!!! 
Τέλος να προσθέσω ότι αν η παράμετρος τις μεθόδου ήταν μεταβλητή άλλου τύπου πχ ctl as Control δεν μου παρουσιάζετε κανένα πρόβλημα, δηλαδή :
Κώδικας:
'----------------------------------------
' clsIMyObject - Interface Class
'----------------------------------------

Public Sub method1(frm As Access.Form) ' <-- Error!!!!!! Giati????
End Sub

Public Sub method2() ' <-- No Error!
End Sub

Public Sub method3(ctl As Control) ' <-- No Error!
End Sub

Public Sub method4(sb As SubForm, str As String) ' <-- No  Error!
End Sub
Μπορείτε να με βοηθήσετε να καταλάβω τον λόγο του συγκεκριμένου σφάλματος? Ελπίζω να έγινα κατανοητός!
Συνημμένα Αρχεία
Τύπος Αρχείου: accdb Implements Interface.accdb (388,0 KB, 17 εμφανίσεις)
Απάντηση με παράθεση
  #2  
Παλιά 17-03-17, 19:25
Το avatar του χρήστη Meteora
Συντονιστής
Όνομα: Νίκος
Έκδοση λογισμικού Office: Ms-Office 2007
Γλώσσα λογισμικού Office: Ελληνική
 
Εγγραφή: 28-12-2008
Περιοχή: Θεσσαλονίκη
Μηνύματα: 1.033
Προεπιλογή

Καλησπέρα,...
Ασχολούμαι με την Access αρκετά χρόνια, έχω φτιάξει αρκετές εφαρμογές, αλλά δεν ασχολήθηκα ποτέ με ο,τι σε προβληματίζει !
Αυτά τα "μαραφέτια" interface Class, Object drop-down list, Class Module: clsMyObject1, ... δεν τα έδωσα ποτέ σημασία, δεν τα χρειάστηκα ποτέ, δεν,...δεν,...
Συμπερασματικά, δεν μπορώ να σε βοηθήσω.

Υστερολόγιο : Αν ξεκινάς τώρα Access θα πρότεινα να τα αφήσεις και όταν με το καλό σχεδιάσεις μια-δυο-τρεις βάσεις (πίνακες - ερωτήματα(SQL) - φόρμες - αναφορές- κώδικας VBA), τότε ψάξε και σε αυτά τα "μαραφέτια" όπως τα χαρακτήρισα, μιας και δεν ξέρω τι είναι...

Καλό ξε-μπέρδεμα / Νίκος
Απάντηση με παράθεση
  #3  
Παλιά 18-03-17, 11:32
Όνομα: Γιάννης
Έκδοση λογισμικού Office: Ms-Office 2013
Γλώσσα λογισμικού Office: Αγγλική
 
Εγγραφή: 01-10-2014
Μηνύματα: 13
Προεπιλογή

Καλημέρα Νίκο
Η αλήθεια είναι ότι με access + vba ασχολούμαι τους τελευταίους 5 μίνες, αλλά έχοντα αφιερώσει πολύ χρόνο και διάβασμα, είμαι σε θέσει να διαχειριστώ με μια σχετική άνεση κάποια βασικά από Vba και access. Έτσι τον τελευταίο καιρό ασχολήθηκα με τις Κλάσης. Κατασκευάζοντας μια Κλάση κατασκευάζεις στην ουσία ένα δικό σου Αντικείμενο-Object στο οποίο του δίνεις τις δικές του Ιδιότητες και Μεθόδους ακόμα και Events! Από ότι καταλαβαίνω μέχρι τώρα, η Κλάσεις είναι η ουσία, η καρδιά του Αντικειμενοστραφή Προγραμματισμού.

Έχω δημιουργήσει μερικές κλάσης (κακογραμμένες βεβαία σε σχέση με κάποιον πεπειραμένο) και πραγματικά είναι ένα ισχυρότατο εργαλείο το οποίο με έχει βοηθήσει πολύ! Πάνε τον κώδικα σε άλλο επίπεδο!

Επειδή σε εχω διαβασει κατά καιρούς και έχω καταλάβει το μεράκι και την αγάπη σου για τον προγραμματισμό Θα σε προέτρεπα , αν έχεις το χρόνο, να εξερευνήσεις και αυτό το μονοπάτι της Vba. Δεν είναι τόσο περίπλοκο όσο φαντάζεσαι για να κατανοήσεις και να εφαρμόσεις κάποια βασικά πραγματάκια, τα οποία θα διαπιστώσεις και μόνο σου ότι θα σε ιντριγκαρουν και θα πάνε την δομή τον εφαρμογών σου ένα άλλο επίπεδο.

Όσο αναφορά την αρχική ερώτηση μου, έχω τη αίσθηση (ίσος βεβαία κάνω λάθος) ότι οποιοδήποτε μέλος του φόρουμ έχει βγάλει μια σχολή σχετική με πληροφορική και έχει ασχοληθεί λίγο με vba, μπορεί με άνεση να καταλάβει τι πραγματεύομαι και να εκφέρει την άποψη του. Για αυτό λοιπόν αναμένω…

Υ.Γ: Σου επισυνάπτω ένα αρχείο όπου περιέχει μια κλάση που έχω φτιάξει και πως την εφαρμόζω. Δεν το δίνω σαν ορθό παράδειγμα καθότι είμαι αρχάριος αλλά για πάρεις γενική αίσθηση αν σε ενδιαφέρει ή αν ποτέ αποφασίσεις να ασχοληθείς με αυτά μαραφέτια να έχεις κάτι χειροπιαστό (έστω και κακογραμμένο, πράγμα που δεν είχα εγώ και θα με βοηθούσε αρκετά).
Συνημμένα Αρχεία
Τύπος Αρχείου: zip Class Example.zip (111,8 KB, 35 εμφανίσεις)
Απάντηση με παράθεση
  #4  
Παλιά 02-04-17, 23:52
Το avatar του χρήστη Meteora
Συντονιστής
Όνομα: Νίκος
Έκδοση λογισμικού Office: Ms-Office 2007
Γλώσσα λογισμικού Office: Ελληνική
 
Εγγραφή: 28-12-2008
Περιοχή: Θεσσαλονίκη
Μηνύματα: 1.033
Προεπιλογή

Καλησπέρα,
...Αργοπορημένη η απάντησή μου, αλλά ευχαριστώ θερμά για την ευγενική σου πρόθεση να δω δείγμα της δουλειάς σου.
Να είσαι καλά, να κάνεις σπουδαίες εφαρμογές και να βοηθάς το Forum / Νίκος
Απάντηση με παράθεση
Απάντηση στο θέμα


Δικαιώματα - Επιλογές
Δε μπορείτε να δημοσιεύσετε νέα μηνύματα
Δε μπορείτε να δημοσιεύσετε απαντήσεις
Δεν μπορείτε να επισυνάψετε αρχεία
Δεν μπορείτε να επεξεργαστείτε τα μηνύματα σας

Ο κώδικας ΒΒ είναι σε λειτουργία
Τα Smilies είναι σε λειτουργία
Ο κώδικας [IMG] είναι σε λειτουργία
Ο κώδικας HTML είναι εκτός λειτουργίας
Trackbacks are εκτός λειτουργίας
Pingbacks are εκτός λειτουργίας
Refbacks are εκτός λειτουργίας



Η ώρα είναι 07:59.