Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Leeren sämtlicher Editfelder mit einer Schleife??? (https://www.delphipraxis.net/3747-leeren-saemtlicher-editfelder-mit-einer-schleife.html)

syber 28. Mär 2003 12:00


Leeren sämtlicher Editfelder mit einer Schleife???
 
Hallo Zusammen

Ich hab ein kleines Problem.

Ich wollte den Inhalt
Code:
edit*.text
(wobei * für die einzelnen Editfelder steht)von 6 Editfelder die ich auf einem formular erstellt habe mit einer Schleife löschen.
Wie es bei einem editfeld geht weiß ich.


Wie lässt sich so etwas am besten realisieren?

Besten Dank

MrSpock 28. Mär 2003 12:04

Hallo syber,

du kannst alle Komponenten durchlaufen und, falls es sich dabei um ein Edit Feld handelt, es löschen. Dann bist du auch unabhängig vom Namen:

Delphi-Quellcode:
for i := 0 to ComponentCount -1 do
  if Components[i] is TEdit then
     (Components[i] as TEdit).Text := '';

Hansa 28. Mär 2003 12:15

Hi,

dazu habe ich zwei Fragen:

1. Habe ich die Felder nicht Edit1, Edit2 usw. benannt, worauf bezieht sich dann das i ?

2. Wie siehts mit dem Gültigkeitsbereich aus ?

MrSpock 28. Mär 2003 12:47

Hallo Hansa,

wenn die EditFelder die Namen Edit1, Edut2, etc. haben, kann man mit der Funktion FindComponent arbeiten und die Komponenten direkt ausfindig machen. Mein Ansatz ist es den Array Components zu durchlaufen, der alle Komponenten z.B. des Formulars enthält. Das "i" wird dann als Index in diesem Array benutzt. So wie ich den Quelltext geschrieben habe, wird die Components Eigenschaft des Formulars benutzt. (Jede Komponente kennt diese Eigenschaft).

syber 28. Mär 2003 12:50

Besten Dank MrSpock.
Hat alles bestens geklappt. So etwas (im entferntesten) **ähnliches** hat mir eben auch ein freund gesagt, blos geklappt hat es nicht :(

Gruß Syber

Daniel B 28. Mär 2003 13:06

Hallo,

vielleicht solltest Du uns auch mitteilen was nicht geht. Funktioniert die Prozedur nicht, oder lässt sich das ganze erst gar nciht kompilieren?

Hast Du auch an die Variablendeklaration gedacht?
Delphi-Quellcode:
procedure dfdfsdfsd(Sender: TObject);
var
  i: Integer;
begin
  //Hier die Schleife
end;
Grüsse, Daniel :hi:

Hansa 28. Mär 2003 13:08

Fragesteller hat seine Lösung, aber ich hake nochmals nach. Das mit der Eigenschaft Components habe ich mir soeben angesehen. Aha. Meine Frage zielt aber eher darauf hinaus, wie ich bestimmte Felder und nicht alle behandeln kann? Z.B. Edit - Felder 10 bis 20. Das wäre dann eben Edit10 bis Edit20, aber nicht bei abgeänderten Namen. Deshalb müsste man doch wissen welche Nr. (in diesem Falle i) zu welchem Editfeld gehört.

X-Dragon 28. Mär 2003 13:33

Zitat:

Zitat von Hansa
Fragesteller hat seine Lösung, aber ich hake nochmals nach. Das mit der Eigenschaft Components habe ich mir soeben angesehen. Aha. Meine Frage zielt aber eher darauf hinaus, wie ich bestimmte Felder und nicht alle behandeln kann? Z.B. Edit - Felder 10 bis 20. Das wäre dann eben Edit10 bis Edit20, aber nicht bei abgeänderten Namen. Deshalb müsste man doch wissen welche Nr. (in diesem Falle i) zu welchem Editfeld gehört.

Wenn man seinen Edit-Feldern Tags zuweist (einfach im Obejktinsp.) kann man die Abfrage beliebig eingrenzen. Bei mir sieht das z.B. so aus:

Delphi-Quellcode:
  for i := 0 to ComponentCount -1 do
    if Components[i] is TEdit then
    begin
      ed := TEdit(Components[i]);
      if ed.Tag > 100 then
        ed.Text := '';
    end;
"ed" muss dabei natürlich als TEdit deklariert sein.

[edit]
damit kann man seine Edit-Felder wenigstens beliebig benennen, im Gegensatz zum unteren Beispiel :)

MrSpock 28. Mär 2003 14:19

Hallo Hansa,

wie gesagt, dabei hilft FindComponent:

Delphi-Quellcode:
for i := 10 to 20 do
begin
   compo := FindComponent('Edit'+IntToStr(i));
   if (compo <> Nil) and (copmo is TEdit) then
      { Hier bearbeiten ...}
end;

Hansa 28. Mär 2003 18:54

Zitat:

Zitat von X-Dragon
Wenn man seinen Edit-Feldern Tags zuweist (einfach im Obejktinspektor),... damit kann man seine Edit-Felder wenigstens beliebig benennen, im Gegensatz zum unteren Beispiel :)

Aha, Tags :idea: Endlich mal eine sinnvolle Aufgabe für die. Nur bei 100 oder mehr Feldern würde es übel aussehen. Die Tags selber verwalten :?: Na gut, immerhin für Ausnahmefälle sehr brauchbar. Der Tip ist echt gut. Eine Alternative wäre noch : nur relevanten Felder ein Tag zuweisen und den anderen aussagekräftige Namen, kann ja auch z.B. AdresseEdit1..AdresseEditX sein. 8) *grübel*

Hansa 23. Apr 2003 12:33

muß das Thema nochmals aufgreifen. Ich brauche jetzt in einem konkreten Fall das ComponentCount. Nur was ist da mit dem Gültigkeitsbereich ? Darüber schweigt die OH leider.

Darty 23. Apr 2003 13:33

Gültigkeitsbereich ?? Meinst DU welche Componenten aufgezählt werden ?

Hansa 23. Apr 2003 17:45

So ungefähr. Gilt das pro Form, pro Projekt oder wie? OH ist etwas zweideutig und der Gültigkeitsbereich ist halt der Bereich, in dem auf eine Variable etc. zugegriffen werden kann. 8)

Andreas L. 23. Apr 2003 18:49

Machs halt gleich so:

procedure TForm1.Button1Click(Sender: TObject);
begin
Edit1.Clear;
Edit2.Clear;
Edit3.Clear;
Edit4.Clear;
Edit5.Clear;
Edit6.Clear;
end;

Hansa 23. Apr 2003 19:09

ja, so was mußte ja kommen. 8) Na gut, dann eben das, was ich vermeiden wollte : eine Form besteht aus 4 Tabsheets auf PageControl. Da drauf liegen insgesamt ca. 60-100 DBedit-Felder. Felder vom gleichen Typ müssen ausgerichtet werden (z.B. integer: rechtsbündig). Die Felder heißen auch nicht Edit1,Edit2 .... sondern haben einen richtigen Namen. Es geht auch nicht um das Clear, sondern um das CommponentCount. Wie Mr. Spock weiter oben geschrieben hat, kann man hierzu die Tags verwenden. Das war ein guter Hinweis. Nur was noch unklar ist : eventuell brauche ich die Tags nicht. Aber nur sofern sich ComponentCount auf die Form bezieht. Gilt das projektweit, so sieht es wieder anders aus.

Andreas L. 23. Apr 2003 19:15

Zitat:

Zitat von Hansa
ja, so was mußte ja kommen. 8) Na gut, dann eben das, was ich vermeiden wollte : eine Form besteht aus 4 Tabsheets auf PageControl. Da drauf liegen insgesamt ca. 60-100 DBedit-Felder. Felder vom gleichen Typ müssen ausgerichtet werden (z.B. integer: rechtsbündig). Die Felder heißen auch nicht Edit1,Edit2 .... sondern haben einen richtigen Namen. Es geht auch nicht um das Clear, sondern um das CommponentCount. Wie Mr. Spock weiter oben geschrieben hat, kann man hierzu die Tags verwenden. Das war ein guter Hinweis. Nur was noch unklar ist : eventuell brauche ich die Tags nicht. Aber nur sofern sich ComponentCount auf die Form bezieht. Gilt das projektweit, so sieht es wieder anders aus.

Oh, wusst ich nicht, sorry!

Hansa 23. Apr 2003 19:19

Zitat:

Zitat von onlinehome
Oh, wusst ich nicht, sorry!

Du brauchst Dich doch nicht für eine Antwort zu entschuldigen. :chat: Ist ja gut, wenn überhaupt eine Antwort kommt. Meine Frage paßt ja auch zumindest nicht zum Anfang des Threads. In den Zusammenhang aber schon.

Andreas L. 23. Apr 2003 19:28

Zitat:

Zitat von Hansa
Zitat:

Zitat von onlinehome
Oh, wusst ich nicht, sorry!

Du brauchst Dich doch nicht für eine Antwort zu entschuldigen. :chat: Ist ja gut, wenn überhaupt eine Antwort kommt. Meine Frage paßt ja auch zumindest nicht zum Anfang des Threads. In den Zusammenhang aber schon.

OK :hello:

danielA 23. Apr 2003 19:37

Hallo erstmal,

habe eben mal kurz in der Unit Classes nachgeschaut und folgendes rausgefunden.

Componentcount, Components etc. umfaßt alle Komponenten, welche der Komponente gehören (AOwner). In deinem Fall währe das also das Form.
Hast du jedoch eigene Komponenten geschrieben, welche ein Editfeld als Unterkomponente besitzen, so wird dieses Editfeld nicht bei einem Durchlauf von ComponentCunt des Form mit aufgefaßt da im Constructor der eigenen Komponente etwa soetwas drinsteht.

Delphi-Quellcode:
class TMeineKompo = Class(TPanel)
private
  Edi : TEdit;

...

implementation

constructor TMeineKompo.Create(AOwner : TComponent);
begin
  inherited;
  Edi := TEdit.Create(self); // <--- AOwner ist also TMeineKompo
  Edi.Parent:=self // <--- gibt nur an, daß es auf TMeineKompo angezeigt werden soll

  ...
 
end;
Aber du kannst sicher sein, alle Komponenten, die du per Drag and Drop oben aus der Leiste auf das Form gezogen hast (auch wenn sie auf einem Panel oder Tabsheet liegen) werden gefunden, da AOwner immer das Form sein wird und nur der Parent auf das Panel bzw. Tabsheet etc. zeigt.

Noch ein Hinweis:

FComponent (private in TComponent) ist ein TListobjekt in dem alle Komponenten eingetragen werden, die diese Komponente besitzt.
Auf FComponent greifen ComponentCount, Components etc zu.
Du solltest dir auch mal den Quelltext von FindComponent anschauen. Es ist auch nur ein Schleife, die alle Namen mit dem String vergleicht. Wenn du also bei allen Felder eines Typs dieselbe Eigenschaft ändern willst, so ist es meines erachtens
nicht besonders Sinnvoll FindComponent zu verwenden.

Gruß danielA

Hansa 23. Apr 2003 20:00

Zitat:

Zitat von danielA
...In deinem Fall währe das also das Form...

Ist das sicher ? Muß es sowieso austesten, dann seh ichs ja. Eigene Komponenten haben ja damit nichts zu tun. Haste meinen "Monster-Thread" (frei nach Motzi) auch gelesen ? War wohl unübersehbar. :mrgreen: Wobei aber noch ein ganz anderer wichtiger Aspekt auftaucht. Leite ich irgendeine Komponente von einer Delphi-Standard-Komponente ab, OHNE irgendwas zu ändern, kann ich gezielt diese Sachen mit ComponentCount, FindComponent usw. auf z.B. TMyEdit anwenden:
Code:
if ... IS TMyEdit
Für Sonderfälle wäre es deshalb eventuell besser, statt TAGs so etwas zu verwenden, also eine eigene Klasse, die dann gesondert behandelt wird. Was wiederum im Klartext eine Zeile ausmacht :

Code:
TMyEdit=class(TEdit);
Stimmt das so?

danielA 23. Apr 2003 20:20

Hallo Hansa,

1. jupp, ist sicher mußte vor jahren schonmal in so einer Schleife auf Parent prüfen, da nur Komponenten die auf einem bestimmten Tabsheet lagen geändert werden durften.

2. Ja den "Monster Thread" konnte man nicht übersehen, fand ich Gut.

Darauf bin ich noch gar nicht gekommen sollte aber Funktionieren.
Aber aufpassen:

Delphi-Quellcode:

var MyEdi : TMyEdit;
    Edit : TEdit;

...
if Edi is TEdit // True
if Edi is TMyEdit // False
if MyEdi is TMyEdit // Klar True
if MyEdi is TEdit // auch True da TEdit Vorfahrklasse
Gruß danielA

Hansa 23. Apr 2003 20:52

Zitat:

Zitat von danielA
if MyEdi is TEdit // auch True da TEdit Vorfahrklasse

Einen Sonderfall muß man auch als solchen behandeln. Das ist wohl klar. Aber das geht wirklich so. Tja, OOP muß man verstanden haben, dann geht vieles einfacher. Deshalb auch dieser "Monster-Thread". :bounce2: Leider befassen sich nur wenige damit.

danielA 23. Apr 2003 21:59

Zitat:

Leider befassen sich nur wenige damit.
Davon kann ich leider auch ein Lied singen.

Gruß danielA


Alle Zeitangaben in WEZ +1. Es ist jetzt 08:48 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