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;

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;

