Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.02.13;
Скачать: CL | DM;

Вниз

Как создать обработчик события...   Найти похожие ветки 

 
Val ©   (2005-02-01 15:16) [0]

Есть объявление:
TMyClass = class
public
  MyDataSet : TDataSet;
end;

Как создать обработчик события MyDataSet.AfterDelete, который выполнит внешний(экземпляр MyDataSet находится на форме) обработчик события MyDataSet.AfterDelete (if Assigned) и за ним свой код, не делая наследника TDataSet?


 
Digitman ©   (2005-02-01 15:28) [1]

Как "СОЗДАТЬ" или как "ДЕКЛАРИРОВАТЬ, РЕАЛИЗОВАТЬ, НАЗНАЧИТЬ" ?


 
Val ©   (2005-02-01 15:32) [2]

Я это имел ввиду, под словом "создать".
Хотелось бы понять принцип хотя бы...


 
Digitman ©   (2005-02-01 15:36) [3]

справку по обработчику события TDataSet.OnAfterDelete читал ? что непонятно там ?


 
Val ©   (2005-02-01 15:56) [4]

Непонятно, каким образом выполнить внешний, существующий обработчик:
1. задекларирую свой обработчик AfterDelete, как метод TMyClass.
2. надо бы назначить его обработчкиом AfterDelete датасета, но, вдруг там есть свой, как его все-таки назначить, но не потерять тот и сначала _его_ выполнять в моем?


 
Digitman ©   (2005-02-01 16:21) [5]

type

TDataSetNotifyEvent = procedure(DataSet: TDataSet) of object;

property AfterDelete: TDataSetNotifyEvent;

ЭТО (фрагмент справки) о чем-нибудь тебе говорит ?!


 
Val ©   (2005-02-01 16:28) [6]

да, спасибо.


 
Val ©   (2005-02-01 16:52) [7]

Вопрос о корректности решения - использовал поле типа TDataSetNotifyEvent для хранения ссылки на внешний обработчик. Вопрос - если мне нужно обработать несколько событий таким образом - делать соотв кол-во полей? Или я все-же придумал "кривое" решение?


 
Digitman ©   (2005-02-01 17:08) [8]


> Вопрос - если мне нужно обработать несколько событий таким
> образом - делать соотв кол-во полей?


наверняка ..

ведь ты же не знаешь заранее, куда "направлены" обработчики различных событий TDATASET на момент когда ты их, так сказать, пытаешься "перехватить" ..


 
Val ©   (2005-02-01 17:12) [9]

Еще раз спасибо.



Страницы: 1 вся ветка

Текущий архив: 2005.02.13;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.027 c
3-1106035711
Bless
2005-01-18 11:08
2005.02.13
Можна ли сделать, чтобы внутри транзакции часть кода не откатывал


11-1090947892
Андрей
2004-07-27 21:04
2005.02.13
TKOLButton + TKOLAction = EAccessViolation at 00000000


1-1106986978
m52
2005-01-29 11:22
2005.02.13
Проблема со скроллингом в ListView


1-1106921084
Chlavik
2005-01-28 17:04
2005.02.13
Системная функция IntfCopy


3-1105699715
Pavelkq
2005-01-14 13:48
2005.02.13
MS Access + ADO = Delphi