我正在使用gson库和Mustach.js模板引擎。我将产品集合传递给jsp页面。
现在我使用以下代码:
Collection<Product> products = productDAO.findAll();
Gson gson = new Gson();
JsonElement element = gson.toJsonTree(products,
new TypeToken<Collection<Product>>() {
}.getType());
JsonArray jsonArray = element.getAsJsonArray();
HttpServletResponse response = ServletActionContext.getResponse();
response.setContentType("application/json");
response.setCharacterEncoding("UTF-8");
PrintWriter writer = response.getWriter();
writer.print(jsonArray);
它生成以下json输出:
[{"name":"Ut Nisi A PC","price":1133.43,"storeId":1,"id":2},
{"name":"Ipsum Dolor Sit Company","price":967.45,"storeId":1,"id":3},
{"name":"Ligula Limited","price":156.66,"storeId":1,"id":100}]
我想要的是命名一个数组:
{
"products":
[{"name":"Ut Nisi A PC","price":1133.43,"storeId":1,"id":2},
{"name":"Ipsum Dolor Sit Company","price":967.45,"storeId":1,"id":3},
{"name":"Ligula Limited","price":156.66,"storeId":1,"id":100}]}
那么在jsp for Mustache.js模板中我可以引用类似的数组:
<div id="container"></div>
<script id="products-template" type="text/mustache-template">
{{#products}}
<li>{{name}},{{price}}</li>
{{/products}}
</script>
$.ajax({
type : 'GET',
dataType : 'json',
url : 'product/upload_products',
success : function(products) {
var template = $('#products-template').html();
var info = Mustache.render(template, products);
$('#container').html(info);
}
})
</script>
如何使用GSON库这样的输出?
答案 0 :(得分:3)
只需创建一个新的JsonObject
并添加一个字段
JsonObject object = new JsonObject();
object.add("products", jsonArray);
然后将该对象写入响应。
答案 1 :(得分:0)
使用JsonObject。所以,
JsonObject jsonObject = new JsonObject();
jsonObject.add("products", jsonArray); // jsonObject has the add method not put.
答案 2 :(得分:0)
Json对象的键始终是String,但值可以是String,布尔值,数字,json数组,....
如果你有一个数组的对象,你只需要将它传递给值中的jsonObject并创建一个String键。
像HashMap一样管理jsonObject。 要做你需要的东西,在一个新的Json对象中创建一个put(&#34; products&#34;,yourJsonArrayObject)。
JsonObject yourNewObject = new JsonObject();
yourNewObject.put("products", yourJsonArrayObject);