Создайте JSON с помощью JSON-Views
Я пытаюсь использовать JSON-Views в Grails 3.1.
У меня есть следующий контроллер:
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
Похож на ошибку. Единственный способ добиться того, что вы ищете, - использовать представления, как показано ниже. Также обратите внимание на использование 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
}*/