![]() |
AW: Mit Datenmodul arbeiten
*gelöscht*
Gruß K-H |
AW: Mit Datenmodul arbeiten
Hallo Walter,
die Trennung macht durchaus Sinn. Wenn man es aber macht, dann bitte konsequent so wie schon mehrfach vorgeschlagen, und nicht irgend so einen Misch-Masch wo sich dann wieder Teile des Datenzugriffes auf den Formularen befinden. Mein Vorschlag: Diese procedure gehört in das Formular
Delphi-Quellcode:
Beim "OnActivate" und "OnDeactivate" würde ich sie jeweils im Formular zuweisen
procedure TfrmMitglieder.dscMitgliederDataChange(Sender: TObject; Field: TField);
begin ... end;
Delphi-Quellcode:
Abgesehen davon würde ich die Datenmodule generell in der .dpr erzeugen, denn oft ist es ja so, dass bei konsequenter Anwendung der Datenmodule (absolute Trennung von Datenzugriff und GUI) dann mehrere Formulare das Datenmodul problemlos verwenden können. Unterm Strich wird zudem sogar der Bildschirmaufbau etwas schneller weil die Tabelle offen bleiben kann und das Datenmodul nicht ständig neu erzeugt werden muss.
procedure TfrmMitglieder.FormActivate(Sender: TObject);
begin dmMitglieder.dscMitglieder.OnDataChange := dscMitgliederDataChange; end; procedure TfrmMitglieder.FormDeActivate(Sender: TObject); begin dmMitglieder.dscMitglieder.OnDataChange := nil; end; |
AW: Mit Datenmodul arbeiten
Zitat:
Der DataSource (auf dem Formular) hat ein OnDataChange-Event (auf dem Formular) das etwas ... auf dem Formular auslöst. Schön einfach und trotzdem sauber getrennt. 8-) |
AW: Mit Datenmodul arbeiten
Zitat:
|
AW: Mit Datenmodul arbeiten
Hallo Otto,
Klappt, Danke |
AW: Mit Datenmodul arbeiten
Zitat:
@Walter Verbesserungsvorschlag:
Delphi-Quellcode:
Was mich bei dieser Gelegenheit zu der Frage veranlasst, wie man es denn eigentlich "richtig" macht?
program Project1;
uses Vcl.Forms, Unit1 in 'Unit1.pas' {Form1}, Unit2 in 'Unit2.pas' {DataModule1: TDataModule}; {$R *.res} begin Application.Initialize; Application.MainFormOnTaskbar := True; // Datenmodule vor dem Hauptformular erzeugen Application.CreateForm(TDataModule1, DataModule1); Application.CreateForm(TForm1, Form1); Application.Run; end. //************************************************************************************** unit Unit1; interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Data.DB; type TForm1 = class(TForm) procedure FormActivate(Sender: TObject); procedure FormDeactivate(Sender: TObject); private { Private-Deklarationen } procedure FormularUpdate(DataSet: TDataSet); public { Public-Deklarationen } end; var Form1: TForm1; implementation {$R *.dfm} uses Unit2; procedure TForm1.FormActivate(Sender: TObject); begin DataModule1.FormularUpdateEvent := FormularUpdate; end; procedure TForm1.FormDeactivate(Sender: TObject); begin DataModule1.FormularUpdateEvent := nil; end; procedure TForm1.FormularUpdate(DataSet: TDataSet); begin // Hier das Formular updaten end; end. //************************************************************************************** unit Unit2; interface uses System.SysUtils, System.Classes, FireDAC.Stan.Intf, FireDAC.Stan.Option, FireDAC.Stan.Param, FireDAC.Stan.Error, FireDAC.DatS, FireDAC.Phys.Intf, FireDAC.DApt.Intf, FireDAC.Stan.Async, FireDAC.DApt, Data.DB, FireDAC.Comp.DataSet, FireDAC.Comp.Client; type TFormularUpdateEvent = procedure(DataSet: TDataSet) of object; TDataModule1 = class(TDataModule) FDQuery1: TFDQuery; procedure FDQuery1AfterScroll(DataSet: TDataSet); procedure DataModuleCreate(Sender: TObject); private { Private-Deklarationen } FFormularUpdateEvent: TFormularUpdateEvent; public { Public-Deklarationen } property FormularUpdateEvent: TFormularUpdateEvent read FFormularUpdateEvent write FFormularUpdateEvent; end; var DataModule1: TDataModule1; implementation {%CLASSGROUP 'Vcl.Controls.TControl'} {$R *.dfm} procedure TDataModule1.DataModuleCreate(Sender: TObject); begin FormularUpdateEvent := nil; end; procedure TDataModule1.FDQuery1AfterScroll(DataSet: TDataSet); begin // Erledige hier alles, das mit dem direkten Zugriff auf // Komponenten im Datenmodul zusammen hängt // ... // Formular aktualisieren: if Assigned(FormularUpdateEvent) then FormularUpdateEvent(DataSet); end; end.
Delphi-Quellcode:
So:
if Assigned(FormularUpdateEvent) then FormularUpdateEvent(DataSet); oder so: if Assigned(FFormularUpdateEvent) then FFormularUpdateEvent(DataSet); |
AW: Mit Datenmodul arbeiten
Zitat:
Willst du das Ergebnis vom Getter oder den Wert der Variablen? Damit entscheidet sich, was du verwenden musst ;) |
AW: Mit Datenmodul arbeiten
Na ja, in diesem Fall ist es was die Funktionalität anbelangt prinzipiell egal. Ich persönlich nehme innerhalb des Objekts lieber die "F"-Variante, wenn die Property direkt auf die Objektvariable zeigt. Mit Getter und Setter würde ich dann lieber auf die Property zugreifen.
|
AW: Mit Datenmodul arbeiten
Die Frage wäre was wäre schneller: Getter per "read FFieldVariable" oder Fieldvariable ?
Ich gehe mal einfach davon aus das der Compiler das inline setzt und gleich schnell sein wird. Aber ist das wirklich so ? Zumindest wenn der Getter per "read GetFieldVariable" mit
Delphi-Quellcode:
gemacht wird vermute ich mal der reine Variablenzugriff ist schneller.
Result := FFieldVariable;
Rollo |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:11 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