JSON 之 SuperObject(6): 方法

SuperObject 的 JSON 对象中还可以包含 "方法", 这太有意思了; 其方法的格式是:

procedure Method(const This, Params: ISuperObject; var Result: ISuperObject);

//另外, 这是其数据类型的枚举:
TSuperType = (stNull, stBoolean, stDouble, stInt, stObject, stArray, stString, stMethod);


测试代码:


unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Keyboard;

type
  TForm1 = class(TForm)
    Button1: TButton;
    Button2: TButton;
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

uses SuperObject;

//方法1; 参数列表是规定好的, 但这里没使用参数
procedure Method1(const This, Params: ISuperObject; var Result: ISuperObject);
begin
  ShowMessage(‘Hello‘);
end;

//方法2; 这里使用了第二个参数; 这里的第二个就是调用时的第一个
procedure Method2(const This, Params: ISuperObject; var Result: ISuperObject);
begin
  ShowMessage(Params.AsJSon);
end;

//方法3; 这里使用了第一个参数; 第一个参数值使用时无需传递, 它代表使用方法的对象本身
procedure Method3(const This, Params: ISuperObject; var Result: ISuperObject);
begin
  ShowMessage(This.AsJSon);
end;

//方法4; 这里使用了第三个参数; 这是调用时的返回值, 如果不给它赋值, 调用时将无返回值
procedure Method4(const This, Params: ISuperObject; var Result: ISuperObject);
begin
  Result := This;
  Result.Merge(Params, True); {合并}
end;

//第一种使用方法
procedure TForm1.Button1Click(Sender: TObject);
var
  jo: ISuperObject;
begin
  jo := SO(‘{"X":"Y"}‘);
  jo.M[‘jm1‘] := @Method1;
  jo.M[‘jm2‘] := @Method2;
  jo.M[‘jm3‘] := @Method3;
  jo.M[‘jm4‘] := @Method4;

  jo.call(‘jm1‘);                      // Hello

  jo.call(‘jm2‘, SO(‘{"A":"B"}‘));     // {"A":"B"}
  jo.call(‘jm2‘, ‘{"A":"B"}‘);         // {"A":"B"}

  jo.call(‘jm3‘);                      // {"X":"Y"}

  jo.call(‘jm4‘, ‘{"B":null}‘);
  ShowMessage(jo.AsJSon);              // {"X":"Y","B":null}
end;

//第二种使用方法
procedure TForm1.Button2Click(Sender: TObject);
var
  t,jo: ISuperObject;
begin
  jo := SO(‘{"X":"Y"}‘);
  jo.M[‘jm1‘] := @Method1;
  jo.M[‘jm2‘] := @Method2;
  jo.M[‘jm3‘] := @Method3;
  jo.M[‘jm4‘] := @Method4;

  jo[‘jm1()‘];                           // Hello

  jo[‘jm2(‘ + ‘{"A":"B"}‘ + ‘)‘];        // {"A":"B"}
  jo[‘jm2({A:B})‘];                      // {"A":"B"}

  jo[‘jm3()‘];                           // {"X":"Y"}

  jo[‘jm4(‘ + ‘{"B":null}‘ + ‘)‘];
  ShowMessage(jo.AsJSon);                // {"X":"Y","B":null}
end;

end.
时间: 2024-10-13 21:23:37

JSON 之 SuperObject(6): 方法的相关文章

AJAX跨域请求json数据的实现方法

这篇文章介绍了AJAX跨域请求json数据的实现方法,有需要的朋友可以参考一下 我们都知道,AJAX的一大限制是不允许跨域请求. 不过通过使用JSONP来实现.JSONP是一种通过脚本标记注入的方式,它是可以引用跨域URL的js脚本,不过需要提供一个回调函数(必须在您自己的页面上),因此,你可以自己处理结果. 让我们看看JSONP的是怎么在jQuery,MooTools的,Dojo Toolkit中实现的. jQuery的JSONPjQuery.getJSON方法:Js代码 jQuery.get

JS:字符串转成json数据,和json转成字符串方法 iframe获取父级传过来的数据

字符串转成json数据,和json转成字符串方法 //转为JSON adinfo=JSON.parse(adinfo) //转为字符串 adinfo=JSON.stringify(adinfo) 大概流程: var gdt_adinfo=[]; 父级页面通过接口获取的数据: this.url="http://gjs.adwo.com/gjs/gad_i?sdkVersion="+sdkVersion+"&n=1&gp="+gp; 获取数据后处理的方法

JSON数据的序列化方法

ajax传参是json数据对象时,最好是将json对象先序列化 var stuAnswerTotal = examModule.touch.getData('examAnswer'); console.log(stuAnswerTotal);//Object对象如下 { 17072={ "id" : 1702, "type":"1",                "val":["",'"&quo

【转】JMeter中返回Json数据的处理方法

Json 作为一种数据交换格式在网络开发,特别是 Ajax 与 Restful 架构中应用的越来越广泛.而 Apache 的 JMeter 也是较受欢迎的压力测试工具之一,但是它本身没有提供对于 Json 数据的响应处理.本文中假设需要从 HTTP 的响应头中返回的 Json 格式的数据流中抽取某些特定的数据,数据格式如下: { "name":"Simpsons family", "members":[ {"firstName"

JMeter中对于Json数据的处理方法

http://eclipsesource.com/blogs/2014/06/12/parsing-json-responses-with-jmeter/ Json作为一种数据交换格式在网络开发,特别是Ajax与Restful架构中应用的越来越广泛.而Apache的JMeter也是较受欢迎的压力测试工具之一,但是它本身没有提供对于Json数据的响应处理.本文中假设需要从HTTP的响应头中返回的Json格式的数据流中抽取某些特定的数据,数据格式如下: { "name":"Sim

使用Python解析JSON数据的基本方法

这篇文章主要介绍了使用Python解析JSON数据的基本方法,是Python入门学习中的基础知识,需要的朋友可以参考下: ----------------------------------------------------------------- Python的json模块提供了一种很简单的方式来编码和解码JSON数据. 其中两个主要的函数是 json.dumps() 和 json.loads() , 要比其他序列化函数库如pickle的接口少得多. 下面演示如何将一个Python数据结构

json 解析乱码解决方法

1. 字符编码的的规律: 字符串的在存入txt文档文档有自身的编码方式,如utf-8,ansi等,但当 存入txt文档时,其编码方式就会和txt文档本身的编码方式保持一致. 比如字符之前的编码方式为ansi,txt文档的编码方式为utf-8,则存入的字符编码方式也会 变为utf-8编码方式.  当从txt文档读出该字符串时,其编码方式也应该是 utf-8. 2. 当前json解析乱码的解决方式 当前json数据的传输方式分为两种: 1). 通信放直接将自身拿到的字符串传输给另一端,在这个过程,无

json对象传入js方法失败

1 var msg:String = {"isBannedUid":"119","isBannedUserId":"112554","isBannedNickName":"test"}; 2 var obj:Object = new Object(); 3 var jsons:String = ""; 4 obj.msg = msg; 5 jsons = JSON.s

jquery解析json格式数据的方法(对象、字符串)

相关函数 函数 描述 JSON.parse() 用于将一个 JSON 字符串转换为 JavaScript 对象. JSON.stringify() 用于将 JavaScript 值转换为 JSON 字符串. //data为字符串类型 则要将字符串类型转换成json数据类型 var jsondatas=eval("("+data+")"); 本文实例讲述了jquery解析json格式数据的方法.分享给大家供大家参考,具体如下: json数据是我们常用的一种小型的数据实