我正在尝试在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": [
{},
{}
]
}
答案 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
}*/