Rendering and JSON
Learn about different ways to render a response.
We'll cover the following
There are many ways to render a response.
Groovy text
If you prefer to use a plain old text document with embedded groovy (much like a GString), you can
use the TextTemplateModule
:
import ratpack.groovy.template.TextTemplateModule;
import static ratpack.groovy.Groovy.groovyTemplate;
import static ratpack.groovy.Groovy.ratpack;
ratpack {
bindings {
module TextTemplateModule
}
handlers {
get(":key") {
def key = pathTokens.key
render groovyTemplate("index.html", title: "$key")
}
}
}
Then create a file named index.html
in the src/main/resources/templates
directory with the following content:
<html><h2>${model.title}</h2></html>
It supplies a model
Map to your template, which contains all of the parameters you supply.
Handlebars and thymeleaf
Ratpack also supports handlebars and thymeleaf templates. Since these are static resources, we
should put these templates in the src/main/resource
directory.
We will first need to include the appropriate ratpack project in your Gradle build file:
runtime 'io.ratpack:ratpack-handlebars:1.1.1'
runtime 'io.ratpack:ratpack-thymeleaf:1.1.1'
To use Handlebars, include the HandlebarsModule
, and render handlebar templates as follows:
import ratpack.handlebars.HandlebarsModule
import static ratpack.handlebars.Template.handlebarsTemplate
import static ratpack.groovy.Groovy.ratpack
ratpack {
bindings {
module HandlebarsModule
}
handlers {
get("foo") {
render handlebarsTemplate('myTemplate.html', title: 'Handlebars')
}
}
}
Create a file named myTemplate.html.hbs
in the src/main/resources/handlebars
directory with handlebar content. For example:
<span>{{title}}</span>
Thymeleaf works in a similar way:
import ratpack.thymeleaf.ThymeleafModule
import static ratpack.thymeleaf.Template.thymeleafTemplate
import static ratpack.groovy.Groovy.ratpack
ratpack {
bindings {
module ThymeleafModule
}
handlers {
get("foo") {
render thymeleafTemplate('myTemplate', title: 'Thymeleaf')
}
}
}
The requested file should be named myTemplate.html
and be located in the src/main/resources/thymeleaf
directory of our project. Example content:
<span th:text=\"${title}\"/>
JSON
Integration with the Jackson JSON marshalling library provides the ability to work with JSON as part of ratpack-core.
The ratpack.jackson.Jackson
class
provides most of the Jackson related functionality. For example,
to render json you can use Jackson.json
:
import static ratpack.jackson.Jackson.json
ratpack {
bindings {}
handlers {
get("user") {
render json([user: 1])
}
}
}
The Jackson integration also includes a Parser for converting JSON request bodies into objects. The
Jackson.jsonNode()
and Jackson.fromJson(Class)
methods can be used to create parcelable objects
to be used with the parse()
method.
For example, the following handler would parse a JSON string representing a Person object and render the Person’s name:
post("personNames") {
render( parse(fromJson(Person.class)).map {it.name} )
}
Context.parse
returns a Promise.
Get hands-on with 1300+ tech skills courses.