0

我正在创建一个测试应用程序,它只是创建一个对象的 JSON 表示并将其发送到模板,然后我想在前端的 JS 脚本中使用 JSON。我正在使用 Ratpack 和 Java Handlebars 来执行此操作。

这是我的 Ratpack 处理程序

class HighChartHandler extends InjectionHandler {

    void handle(Context ctx, TestDataJson testDataJson) {
        testDataJson.goals = 1000
        testDataJson.name = "Nick"
        def jsonData = json(testDataJson)
        ctx.render(handlebarsTemplate('highchartTest.html', model: jsonData))
    }
}

然后我尝试使用简单地在页面上呈现数据

<h1>Graph Test</h1>
<p>This is a WIP highchart test</p>
<p>{{model}}</p>

但是我收到此消息:

ratpack.jackson.internal.DefaultJsonRender@467db85c

我想简单地渲染类似的东西

{"name":"Forlan","goals":1000}
4

2 回答 2

1

您正在使用的方法,Jackson.json(Object) https://ratpack.io/manual/current/api/ratpack/jackson/Jackson.html#json-java.lang.Object-其返回类型为JsonRender https://ratpack.io/手册/当前/api/ratpack/jackson/JsonRender.html

因此,当您通过模板运行它时,它只是调用“JsonRender#toString() which results in what you're seeing:ratpack.jackson.internal.DefaultJsonRender@467db85c`

Jackson.json方法返回 Ratpack 中已知的Renderer. 它告诉 Ratpack 如何表示您提供给Renderer.

为了生成与 html 混合的 json,我会做这样的事情:

def jsonData = new groovy.json.JsonOutput.toJson(testDataJson)
ctx.render(handlebarsTemplate('highchartTest.html', model: [model: jsonData]))

我没有对此进行测试,但它应该可以工作。

于 2016-12-09T02:40:47.983 回答
-1

尝试使用

<p>Name: {{name}}</p>
<p>Goals: {{goals}}</p>

代替

<p>{{model}}</p>
于 2016-12-07T13:59:24.157 回答