其实,只要数据没有Post,可以从OldValue得到procedure TForm1.ClientDataSet1ClientDataSet1Field1Change(Sender: TField); var Save: Variant; begin Save := TField(Sender).OldValue; end;
procedure Tdtmda_CustSpePrice.adsMasterUnitIDChange(Sender: TField); var //Column :TColumnEh; UnitName:string; exchangeRate:real; begin inherited; if not (adsMaster.State in [dsEdit,dsInsert]) then exit; if adsMaster.FieldByName('UnitID').AsString='' then exit; if FOldUnitID <> '' then exchangerate := getUnitChangeRate(adsMaster.FieldByName('ProductID').AsString,FOldUnitID, Sender.AsString) else exchangerate := 1; FOldUnitID:= OldValue; //************************** OldValue:= adsMaster.FieldByName('UnitID').AsString;//**************************end; procedure Tdtmda_CustSpePrice.adsMasterAfterScroll(DataSet: TDataSet); begin inherited; OldValue:= DataSet.FieldByName('UnitID').AsString; end;是这个意思 搞定了 谢谢楼上所有的XD, 新年快乐 祝自己安全度过本命年~
var
Save: Variant;
begin
Save := TField(Sender).OldValue;
end;
----------------
我要的功能是:
假如第一次是 米,然后onchange成公里, 把米存在FOldUnit里,然后再把改变后的公里存在FNewUnit里 就是每一次change的时候把还没change前的Unit保存下来,然后再把change后的Unit也保存下来
你上面说的功能我不明白要干什么,为什么改变了以后不保存到数据集?
不过,你要的这个功能也很简单,第一次改变前或者改变时,你从BeforeScroll或者Oldvalue保存到FOldUnit,然后,在Field.OnChange事件中比较Field.Value和FOldUnit,如果不相等,你再重新保存阿,你甚至可以用List保存每一次的改变。
祝winxkm(蹩脚的程序员) 新年好!
var
//Column :TColumnEh;
UnitName:string;
exchangeRate:real;
begin
inherited;
if not (adsMaster.State in [dsEdit,dsInsert]) then exit;
if adsMaster.FieldByName('UnitID').AsString='' then exit; if FOldUnitID <> '' then
exchangerate := getUnitChangeRate(adsMaster.FieldByName('ProductID').AsString,FOldUnitID, Sender.AsString)
else exchangerate := 1;
FOldUnitID:= OldValue; //**************************
OldValue:= adsMaster.FieldByName('UnitID').AsString;//**************************end;
procedure Tdtmda_CustSpePrice.adsMasterAfterScroll(DataSet: TDataSet);
begin
inherited;
OldValue:= DataSet.FieldByName('UnitID').AsString;
end;是这个意思 搞定了 谢谢楼上所有的XD, 新年快乐 祝自己安全度过本命年~