NAME
Dancer::Template::Handlebars - Wrapper for the Handlebars template system
VERSION
version 0.2.1
SYNOPSIS
# in config.yml
template: handlebars
engines:
handlebars:
helper_modules:
- MyApp::HandlebarsHelpers
# in the app
get '/style/:style' => sub {
template 'style' => {
style => param('style')
};
};
# in views/style.mustache
That's a nice, manly {{style}} mustache you have there!
DESCRIPTION
Wrapper for Text::Handlebars, the Perl implementation of the Handlebars templating system.
Configuration
The arguments passed to the 'handlebars' engine are given directly to the Text::Handlebars constructor, with the exception of helper_modules
(see below for details).
Calls to 'template()'
When calling template
, one can use a filename as usual, or can pass a string reference, which will treated as the template itself.
get '/file' => sub {
# look for the file views/my_template.hbs
template 'my_template', {
name => 'Bob',
};
};
get '/string' => sub {
# provide the template directly
template \'hello there {{name}}', {
name => 'Bob',
};
};
The default extension for Handlebars templates is 'hbs
'.
Helper Functions
Handlebars helper functions can be defined in modules, which are passed via helper_modules
in the configuration. See Dancer::Template::Handlebars::Helpers for more details on how to register the functions themselves.
Layouts
Layouts are supported. The content of the inner template will be available via the 'content' variable.
Example of a perfectly valid, if slightly boring, layout:
<html>
<body>
{{ content }}
</body>
</html>
SEE ALSO
- Dancer::Template::Mustache - similar Dancer wrapper for Template::Mustache.
AUTHOR
Yanick Champoux <yanick@babyl.dyndns.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Yanick Champoux.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.