![]() |
Frame: Button OnClick handler manchmal nicht zugewiesen?
Hallo,
gegeben ist ein Delphi 11.1 VCL-Frame mit u.a. 2 Buttons drauf. Dieses Frame ist in 2 Dialogen eingebunden. In einem funktionieren beide Buttons, im anderen feuert nur der eine seinen OnClick Handler im Frame. Schaut man die Ereignisse beider Buttons in beiden Formularen an, ist jeweils kein OnClick Handler definiert. Das scheint aber richtig zu sein, da dieser ja jeweils im Frame definiert ist. Woran kann das liegen? Grüße TurboMagic |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Hallo,
du klickst die Buttons mit der Maus an? Ist auf dem 2. Form ein Grid? |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Schau dir unbedingt die DFM-Dateien der beiden Formulare an.
Mir ist das schon untergekommen dass auf einem Formular dann tatsächlich explizit stand
Delphi-Quellcode:
. Im Objektinspektor bekommt man davon nichts mit.
meinFrame.meinButton.OnClick = nil
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Mir passiert es manchmal, dass ein Event, der im Frame nachträglich hinzugefügt wurde, von dem Form aus, auf dem der Frame liegt, nicht feuert.
Dann erzeuge ich den Event nochmal vom Form aus und lasse ihn leer. Bein nächsten Speichern wird er wieder automatisch entfernt, aber die Verbindung zum Event auf dem Frame ist wieder hergestellt. Was da intern genau passiert, weiß ich allerdings auch nicht. |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
1. Nein, es ist kein Grund drauf
2. Danke für die Tipps mit dem dfm prüfen und Event neu zuweisen. Zu letzterem wäre Mal zu schauen ob das in QP erfasst ist und wenn nicht dann bitte erfassen und Nummer hier melden. 3. Ich habe auch schon Mal das Frame entfernt und neu hinzugefügt aber ohne Erfolg Grüße TurboMagic |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
Aber achtung: man darf wirklich nur die Zeile mit dem nil löschen, die darüber mit dem inherited button darf man nicht löschen, sonst sind plötzlich alles icons und so im ganzen Formular weg ;-) Aber wozu gibt's ja Versionskontrolle? ;-) |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Hallo,
MMX EventView wäre vielleicht hier ein Check-Instrument. |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Wegen solcher spaßigen Probleme, bei denen man dann ggf. stundenlang nach der Ursache sucht, bin ich dazu übergegangen, Frames nicht mehr zur Designtime auf Formularen zu platzieren. Es gibt nur noch ein Panel als Platzhalter und die Frames werden zur Laufzeit erzeugt und platziert. Dann kann sowas nicht mehr passieren.
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Hallo,
danke für den Tipp das zur Laufzeit zu platzieren. Die Frage wäre jetzt halt, ob alle diese Probleme schon in QP erfasst sind, in der Hoffnung, dass die dann der Reihe nach mal abgearbeitet werden. Man möchte sein RAD Tool ja schließlich auch als RAD Tool benutzen... ;-) Grüße TurboMagic |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Könnte dies hier sein:
![]() |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Sieht ganz danach aus. Habe gleich mal dafür gestimmt ;-)
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Weiterer Bonus: Man kann die Frame-Units in die Uses-Clause des Implementation Teil verlagern oder gleich die Frames über ein Factory-Pattern erzeugen. Das reduziert den Dependency-Wert oft gewaltig und sorgt nebenbei für eine strukturiertere Architektur.
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
Siehe auch ![]() Zitat:
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
Zitat:
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Abgesehen davon sagt das Zitat das genaue Gegenteil von dem was es meint...
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Ja, ich versuche auch immer ALLES, was möglich ist, im Interface anzugeben.
Da ist dann auch die Reihenfolge sichergestellt. Es gibt aber auch Kollegen, die sind vehement der Meinung, dass man ALLES was möglich ist, in die Implementation machen MUß! :wall: Im Interface wird ALLES so wie es da steht, in der Reihenfolge vor der eigenen Unit geladen/initialisiert. Wenn etwas in den eingebundenen Units geladen wird, dann das natürlich entsprechend auch wieder zuerst. In Implementation kann unterliegt die Reihenfolge im USES dem Gutdünken des Compilers und es kann sogar passieren, dass Units erst nach dem eigenen Initialization, bzw. nach eigenen Class-Constructor's vorhanden ist. Greift man also im Initialization/ClassConstructor auf eine Variable/Funktion zu, kann es sein, das diese noch garnicht initialisiert ist, wenn die Unit im Implementation steht ... wenn in Interface, dann ist es immer schon da. Genau andersrum beim Finalizaition, da kann es, wenn im Uses der Implementation, dann schon weg sein, bevor das eigenen Finalization/ClassConstructor anläuft. |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
Damit verbirgt man die Details der Implementierung, die ja niemanden was angehen. Natürlich gibt es keine Regel ohne Ausnahme, aber für mich gehört nur das in den Interface-Teil was da unbedingt nötig ist. (We agree to disagree) |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
Im Idealfall hab ich so aber auch nur ein Uses, was ich irgendwie schon bissl übersichtlicher empfinde. Im Interface ist es immer in der selben Reihenfolge. In der Implementation könnte, selbst bei unverändertem Code, bei jedem Compilieren was in einer anderen Reihenfolge geladen werden, was bei einer Fehlersuche besonders viel Spaß macht. Aber das Wichtigste, im Interface habe ich nie "ausversehn" mal unbemerkte Kreisreferenzen drin ... in der Implementation fällt dir das nie auf, außer da unten steht nur das drin, was absichtlich dort steht, wegen einer bekannten Kreuz-/Kreisreferenz. |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
![]() Zitat:
Zitat:
Aber ich denke, das Thema ist zumindest hier nun ausreichend diskutiert. Wir können das gerne an anderer Stelle vertiefen wenn du möchtest. |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Ich sehe das wie Uwe. Weiterer Vorteil: Änderungen an Units, die in der Implementation Uses-Liste stehen, erfordern kein Neuerstellen der sie verwendenden DCUs. Nicht, dass das bei einem One-Pass-Compiler groß in's Gewicht fiele.
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Btw: gibts eigentlich ein Tool, welches
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Peganza's Pascal Analyzer (vermutlich auch die Lite Version) gibt das zumindest als Report aus. Eine automatische Änderung ist auch nicht immer sinnvoll, da gelegentlich die IDE auf bestimmte Units im Interface-Teil pocht und auch andere Gründe gegen eine Verlagerung in den Implementation-Teil sprechen können (z.B. Reihenfolge von WinApi.Windows und System.Sysutils o.ä.).
Für die manuelle Verschiebung vom einen in den anderen Teil verwende ich immer die entsprechende Funktion (Shift-Ctrl-Alt-Up/Down innerhalb einer uses-Anweisung) im MMX Code Explorer. |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
"gar nicht verwendet" ist auch nicht immer zutreffend.
Ich kann eine Unit einbinden, welcher im Initalization sich irgendwo registriert, was ich dann später benötige, aber dennoch nirgendwo anschließend im Code direkt auf diese Unit direkt zugreifen. Automatisch rausgeworfen darf also garnicht werden. |
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Zitat:
|
AW: Frame: Button OnClick handler manchmal nicht zugewiesen?
Man kann diese Units auch explizit im Projekt einbinden. Die Units in der DPR werden überwiegend sowieso dort nicht direkt verwendet.
In letzter Zeit spendiere ich solchen Units wenn möglich eine Register/Unregister Prozedur, die dann bei Bedarf aufgerufen werden. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:26 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz