Создайте 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
}*/