Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7) (https://www.delphipraxis.net/184210-arbeiten-mit-mehreren-forms-vermeiden-zirkulaerer-referenz-xe7.html)

wonkos2 10. Mär 2015 08:10

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
Zitat:

Zitat von himitsu (Beitrag 1292825)
Und der Nächste, mit dem selben Problem, weiß jetzt natürlich ganz genau, wie du es gelöst hast, wenn er in 1-2 Jahren diesen Beitrag in der SuFu entdeckt. :thumb: :roll:

OK, dann will ich mal beschreiben, was ich gemacht habe: Der Hinweis, meine FormA (also die primäre) unterhalb der unteren Uses-Klausel, nämlich innerhalb der implementation unterzubringen, hat meine zirkuläre Referenz aufgelöst. Jetzt muß ich nur noch das Variablenproblem lösen, dann bin ich einen Schritt weiter. OK?

Luckie 10. Mär 2015 08:45

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
Und was spricht gegen die Lösung von DeddyH und mir? Anstatt so ein Gewurstelt mit den uses Klauseln?

DeddyH 10. Mär 2015 08:47

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
Ja eben. Auch wenn der Compiler jetzt zufrieden ist, bleibt ja die Tatsache, dass sich beide Formulare gegenseitig kennen müssen.

himitsu 10. Mär 2015 08:52

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
Zitat:

Zitat von DeddyH (Beitrag 1292886)
bleibt ja die Tatsache, dass sich beide Formulare gegenseitig kennen müssen.

Besser nicht!

Einer bietet Schnittstellen (Funktionen/Events/Property) an und der Andere benutzt sie, ohne daß Ersterer weiß wer/was er ist, bzw. ob es ihn überhaupt gibt.


Nur so ist es wiederverwendbar, austauschbar, wartbar, ...

DeddyH 10. Mär 2015 08:53

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
Genau darum geht es Luckie und mir doch, wurde aber nicht umgesetzt.

himitsu 10. Mär 2015 09:11

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
Zitat:

Zitat von DeddyH (Beitrag 1292890)
Genau darum geht es Luckie und mir doch, wurde aber nicht umgesetzt.

Ups, falsch gelesen verstanden. :oops:

Zusammen mit der übersehenen Antwort von wonkos2, ergibt es mehr Sinn.


Zitat:

hat meine zirkuläre Referenz aufgelöst.
Nicht aufgelöst, sondern nur abgeschwächt.

Und das Abschwächen kann böse Nachwirkungen haben. (Initialisierungsreihenfolge)
Besser möglichst alle Units nur im Interface einbinden.

Sir Rufo 10. Mär 2015 09:11

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
Auf die ganz billige Art und Weise löst man das mit einem DataModule.

Dort sind die Daten und die Forms zeigen die Daten an. Schon kennen die Forms nur noch das DataModule und nicht mehr sich selber untereinander.

stahli 10. Mär 2015 18:20

AW: Arbeiten mit mehreren Forms, Vermeiden zirkulärer Referenz (XE7)
 
@wonkos2

Damit Du vielleicht besser verstehst, was die Profis meinen: Man solle z.B. den Kunden-Vornamen nicht in EditVorname.Text speichern.
Wenn Du eine Rechnung druckst, muss sonst der Reportgenerator Deine Formularinstanz kennen.

Die Daten und die Geschäftslogik sind daher besser in eigenen Klassen aufgehoben oder hilfsweise in einem Datenmodul.

Die Formulare sind eigentlich nur eine Schnittstelle für den Anwender.

Du kannst natürlich Dein Projekt mit den Daten und Geschäftslogik in Formularen umsetzen, aber wenn Du später Dein Projekt mal ausbauen willst wirst Du dann erhebliche Probleme bekommen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:04 Uhr.
Seite 2 von 2     12   

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