如何在GWT中使用3方json服务

时间:2013-03-16 11:53:33

标签: gwt jsonp gwtquery gquery

我正在寻找GWT中访问3方json休息服务的最佳方式,并快速解析其响应。其余服务提供callback参数,他们给我们的示例是使用jQuery.jsonp:

$.ajax({
  type: 'GET',
  url: 'http://server_name?id=and_id&callback=?',
  contentType: "application/json",
  dataType: 'jsonp',
  success: function(js) {/*{id='id',status='sold',prod_name='name',price=0.0 ...}*/},
  error: function(e) {}
});

1 个答案:

答案 0 :(得分:0)

虽然GWT带有JsonpRequestBuilder来通过脚本标签执行请求,AutoBeans来处理json响应并生成java实现,但我更喜欢gwtquery Ajax和{{3因为它简单。

在您的情况下,您可以使用与提供商提供的语法几乎相同的语法:

  ajax("http://server_name?id=and_id&callback=?",
       $$("type:'get', dataType: 'jsonp'),
       new Function() {
        public void f() {
          Properties jso = getDataProperties();
          String status = jso.get("error");
        }
  });

如果您更喜欢使用构建器,因为您喜欢get / setter,您的代码可能如下所示:

  public static interface MResponse extends JsonBuilder {
    String getId();
    String getStatus();
    String getProd_name();
    double getPrice();
  }

  ajax(Ajax.createSettings()
           .setType("get")
           .setDataType("jsonp")
           .setUrl(""))
    .done(new Function() {
      public void f() {
        MResponse resp = GWT.<MResponse>create(MResponse.class)
                            .load(getDataProperties());
        String status = resp.getStatus();
      }
    });