QJson和QMsgPack提供了对RTTI的支持,让你可以简洁方便的完成数据的转换存贮。因为QJson和QMsgPack在RTTI接口上是一致的,因此本文以QJson为例予以说明,如果要换成QMsgPack,只需要将类型声明换下就好:)。
1、记录类型
我们提供了FromRecord/ToRecord两个函数来完成记录类型的读写操作。FromRecord将一个记录类型的内容转储到QJson或QMsgPack中,ToRecord是从QJson或QMsgPack中恢复记录的内容。
下面是一个FromRecord的简单例子:
type
TMyRecord=record
Name:String;
Age:Integer;
end;
...
var
ARec: TMyRecord;
AJson:TQJson;
begin
AJson:=TQJson.Create;
ARec.Name:='Joney';
ARec.Age:=12;
try
AJson.FromRecord<TMyRecord>(ARec);
ShowMessage(AJson.AsJson);
finally
FreeAndNil(AJson);
end;
end;
ToRtti的例子(接上面的例子):
var
ARec: TMyRecord;
AJson:TQJson;
begin
AJson:=TQJson.Create;
AJson.Add('Name').AsString:='Kitty';
AJson.Add('Age').AsInteger:=32;
try
AJson.ToRecord<TMyRecord>(ARec);
ShowMessage('ARec.Name='+ARec.Name+',ARec.Age='+IntToStr(ARec.Age));
finally
FreeAndNil(AJson);
end;
end;2、对象
我们使用FromRtti和ToRtti两个函数来完成对记录类型的读写操作。同上,FromRtti将一个对象转储到QJson或QMsgPack中,ToRtti是从QJson或QMsgPack中恢复对象的内容。
var AButton: TButton; AJson:TQJson; begin AJson:=TQJson.Create; try AJson.FromRtti(Button17); ShowMessage(AJson.AsJson); finally FreeAndNil(AJson); end; end;
ToRtti的例子:
var
AButton: TButton;
AJson:TQJson;
AOld:String;
begin
AJson:=TQJson.Create;
AJson.Add('Caption').AsString:='ChangedByJson';
try
Button17.Caption:='Button17';
AJson.ToRtti(Button17);
ShowMessage('Button17.Caption='+Button17.Caption);
finally
FreeAndNil(AJson);
end;
end;3、调用函数
我们提供Invoke函数来直接使用QJson或QMsgPack的数据来调用一个函数,函数名由当前结点的名称来确定,参数由子结点提供,QJson或QMsgPack按名称对应到函数的参数中,然后完成调用并返回结果。
Invoke的调用示例:
function TForm1.Add(X, Y: Integer): Integer;
begin
Result := X + Y;
end;
...
var
AJson: TQJson;
AValue: TValue;
begin
AJson := TQJson.Create;
try
with AJson.Add('Add') do
begin
Add('X').AsInteger := 100;
Add('Y').AsInteger := 200;
end;
AValue := AJson.ItemByName('Add').Invoke(Self);
mmResult.Lines.Add(AJson.AsJson);
mmResult.Lines.Add('.Invoke=' + IntToStr(AValue.AsInteger));
finally
AJson.Free;
end;
end;





