使用JSON视图生成JSON

时间:2016-02-08 16:10:50

标签: json grails grails-3.0 json-view

我正在尝试在Grails 3.1中使用JSON-Views

我有以下控制器:

package myapp

BasketController {

    def index(ProductFilterCommand cmd) {

        [basketList: service.findAllBaskets()]
    }
}

以下课程:

package myapp

class Basket {
    List<BasketItem> items
}

class BasketItem  {
    String name 
}

以下是我认为可行的gson文件:

篮/ index.gson

import myapp.Basket

model {
    Iterable<Basket> basketList
}

json.baskets(basketList) {
    g.render(template: "basket", model: [basket: it])
}

篮/ _basket.gson

import myapp.Basket

model {
    Basket basket
}

json.items(basket.items) { 
    g.render(template: "item", model:[item: it])
}

篮/ _item.gson

import myapp.Item

model {
    Item item
}

json g.render(item)

我想生成json,例如:

{
    "baskets": [{
        "items": [{
            "name": "T-shirt"
        }, {
            "name": "Pants"
        }]
    }, {
        "items": [{
            "name": "T-shirt"
        }, {
            "name": "Pants"
        }]
    }]
}

但相反,我得到了:

{
  "baskets": [
    {},
    {}
  ]
}

1 个答案:

答案 0 :(得分:10)

对我来说看起来像个错误。实现您所需要的唯一方法是使用如下所示的视图。另请注意collection而非model的使用情况。我会在下面测试的示例应用程序中提交一个错误。

  

请注意将模板用作完全限定名称basket/item。这是   缺陷。

//index.gson
import com.example.Basket

model {
    Iterable<Basket> basketItems
}

json {
    baskets g.render(template: 'basket', collection: basketItems, var: 'basket')
}

//_basket.gson
import com.example.Basket

model {
    Basket basket
}

json {
    items g.render(template: "basket/item", collection: basket.items, var: 'item')
}

//_item.gson
import com.example.BasketItem

model {
    BasketItem item
}

json g.render(item)

//or if id is not required in response
/*json {
    name item.name
}*/