Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 475

•  TDictionary Custom Sort  6 506

•  Fast Watermark Sources  6 296

•  3D Designer  9 239

•  Sik Screen Capture  6 631

•  Patch Maker  7 005

•  Айболит (remote control)  7 014

•  ListBox Drag & Drop  5 885

•  Доска для игры Реверси  97 140

•  Графические эффекты  7 214

•  Рисование по маске  6 515

•  Перетаскивание изображений  5 383

•  Canvas Drawing  5 758

•  Рисование Луны  5 467

•  Поворот изображения  4 993

•  Рисование стержней  3 548

•  Paint on Shape  2 814

•  Генератор кроссвордов  3 685

•  Головоломка Paletto  2 971

•  Теорема Монжа об окружностях  3 774

•  Пазл Numbrix  2 489

•  Заборы и коммивояжеры  3 172

•  Игра HIP  2 138

•  Игра Go (Го)  2 073

•  Симулятор лифта  2 449

•  Программа укладки плитки  2 116

•  Генератор лабиринта  2 593

•  Проверка числового ввода  2 268

•  HEX View  2 597

•  Физический маятник  2 211

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Синхронизация таблицы и StringList



Автор: OAmiry (Borland)

Допустим что вы имеете TTable с именем Table1 и DBGrid с именем DBGrid1:

  1. В секции модуля interface объявите переменную:

  2. FieldLst: TStringList;
    

  3. Установите свойство формы KeyPreview в TRUE
  4. В обработчике события формы OnCreate добавьте:

  5. FieldLst := TStringList.Create;
    

  6. В обработчике события формы OnDestroy добавьте:

  7. FieldLst.Free;
    

  8. В обработчике события формы OnKeyUp добавьте:

  9. if (ssCtrl in Shift) and (Key in [Ord('D'), Ord('d')]) then
    if (FieldLst.Count > 0 ) then
    begin
    {Если вам необходимы все предыдущие данные полей}
    {for nFld := 0 to Table1.FieldCount - 1 do
    Table1.Fields[nFld].AsString := FieldLst.Strings[nFld] ;}
    
    
    {Если вы хотите только поле, с которым сейчас имеете дело }
    DBGrid1.Fields[DBGrid1.SelectedIndex].AsString := FieldLst.Strings[DBGrid1.SelectedIndex];
    end ;
    

  10. Обработчик события таблицы BeforeInsert должен выглядеть следующим образом:

  11. procedure TForm1.Table1BeforeInsert(DataSet: TDataset);
    var
    nFld: Integer ;
    bmPos: TBookMark ;
    begin
    if (not Table1.BOF) and (Assigned( FieldLst )) then
    try
    bmPos := Table1.GetBookMark ;
    Table1.DisableControls ;
    Table1.Prior ;
    FieldLst.Clear ;
    for nFld := 0 to Table1.FieldCount - 1 do
    FieldLst.Add( Table1.Fields[nFld].AsString ) ;
    Table1.GotoBookMark( bmPos ) ;
    Table1.FreeBookMark( bmPos ) ;
    Table1.EnableControls ;
    except
    on E: EOutOfMemory do ShowMessage( E.Message ) ;
    end ;
    end;
    

Надеюсь, что это будет работать. {Обратите внимание, что при обработке события OnKeyUp вы можете воспользоваться закомментаренными строками, которые позволят вам с помощью комбинации клавиш Ctrl-D получить все предыдущие данные полей. Если вы уберете этот комментарий, то не забудьте прокомментировать строку с DBGrid1....}





Похожие по теме исходники

Custom StringList Sort




Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте