![]()  | 
	
 
  | 
		
			
  | 	
	
	
		
		|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны | 
![]()  | 
	
	
| 
		 | 
	Опции темы | Поиск в этой теме | Опции просмотра | 
| 
		 
			 
			#1  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Допустим на форме есть 100 элементов Edit. 
		
	
		
		
		
		
		
	
		
		
	
	
	Edit1-Edit100 соответственно. Как в цикле For (или в другом) организовать последовательный перебор всех Edit'ов с присвоением какого-либо (одинакового!) значения??? Хотелось бы получить что-то похожее на: Код: 
	For i:=1 to 100 do Form1.Edit[i].color:=clRed;  | 
| 
		 
			 
			#2  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Код: 
	for i := 0 to ComponentCount-1 do if Components[i] is TEdit then (Components[i] as TEdit).Color := clRed;  | 
| 
		 
			 
			#3  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Не совсем подходит... 
		
	
		
		
		
		
		
	
		
		
	
	
	На форме стоит PageControl, а данная функция перебирает все элементы формы... А их там может быть.... Другого способа нет с обращением к конкретному типу элементов сразу?  | 
| 
		 
			 
			#4  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Сколько их там может быть? 1000? 10000? Не думаю, что больше... В любом случае, думаю, функция будет работать достаточно быстро. 
		
	
		
		
		
		
			
		
		
		
		
	
		
		
	
	
	Другой способ - заносить все необходимые экземпляры в массив при старте программы - и перебирать его...  | 
| 
		 
			 
			#5  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 ок. Тогда ещё вопрос по данной функции, если перебираем не все элементы формы а все элементы находящиеся в TabSheet1(2,3,4,5...) и нужно не 100 из 100, а с Edit63 по Edit100? 
		
	
		
		
		
		
		
	
		
		
	
	
	 | 
| 
		 
			 
			#6  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Так и напиши -  
		
	
		
		
		
		
			
		
		
		
		
	
		
		
	
	
	Код: 
	  for i := 0 to TabSheet1.ComponentCount-1 do
    if TabSheet1.Components[i] is TEdit then
      for j := 63 to 100 do
        if (TabSheet1.Components[i] as TEdit).Name = 'Edit' + IntToStr(j) then
          (TabSheet1.Components[i] as TEdit).Color := clRed; | 
| 
		 
			 
			#7  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Код: 
	procedure SetTextToEditByName(EditName, NewText: String); var e: TEdit; begin e := FindComponent(EditName); if e <> nil then e.Text := NewText; end; Примерно так (по имени). Доработать для твоей заачи - 2 минуты (добавить цикл и что там еще).  | 
| 
		 
			 
			#8  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Цитата: 
	
 Если я правильно понял то вместо: Код: 
	Form1.Edit63.color:=clRed; ... Form1.Edit100.color:=clRed; Видимо лучше всё таки прописывать каждый элемент вручную...((( Если я всё правильно понимаю, то по сути задача присвоения значений в цикле группе одинаковых элементов должна сводится к значительному уменьшению объёма кода, а не к увеличению количества действий... Цитата: 
	
 Здесь можно по подробнее? я понял что должно быть примерно так: Код: 
	var e: TEdit; begin For i:=63 to 100 do begin e := FindComponent(Edit+i); if e <> nil then e.Text := NewText; end; end; Последний раз редактировалось kadnikov, 03.08.2010 в 22:16.  | 
| 
		 
			 
			#9  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Можно так, но без проверки выхода за пределы массива 
		
	
		
		
		
		
		
	
		
		
	
	
	Код: 
	var
 i: Integer;
begin
 for i := 63 to 100 do
  (FindComponent('Edit'+IntToStr(i)) as TEdit).Color := clRed;
end; | 
| 
		 
			 
			#10  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Цитата: 
	
 этот вариант подходит, но есть два вопроса: 1. В каком случае может произойти выход за пределы массива? 2. В случае когда элементу присваивается несколько значений, или проверяются условия на ввод данных в группе, логично сделать так: Код: 
	procedure TForm1.Button4Click(Sender: TObject);
begin
For x:=2 to 26 do
begin
e:=(FindComponent('Edit'+IntToStr(x)) as TEdit);
e.Color := clRed;
...
end;
end;Код: 
	Form1.e.Color:=clRed  | 
| 
		 
			 
			#11  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 1) За пределы массива имелось ввиду то, что цикл бежит от, например, Edit3 до Edit34, на у вас на форме нету компонента с именем, допустим, Edit16 - следовательно программа, пытаясь изменить к/л свойство этого элемента вылетит с ошибкой. 
		
	
		
		
		
		
		
	
		
		
	
	
	2) Да когда требуется изменять несколько свойств рациональнее делать и так. 3) В вашем случае переменная E принадлежит вызываемой процедуре, а вот функция FindComponent принадлежит форме, тобишь: Form1.FindComponent.  | 
| 
		 
			 
			#12  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 Цитата: 
	
  |