GRMustache default configuration contains a library of predefined keys available for your templates:
As a filter, HTML.escape
returns its argument, HTML-escaped. Since Mustache generally provides HTML-escaping, this filter will generally be used in conjunction with other escaping filters. For example:
<script type="text/javascript">
$("element").html("{{{ javascript.escape(HTML.escape(content))) }}}")
</script>
As a rendering object, HTML.escape
escapes all inner variable tags in a section:
{{# HTML.escape }}
{{ firstName }}
{{ lastName }}
{{/ HTML.escape }}
Variable tags buried inside inner sections are escaped as well, so that you can render loop and conditional sections:
{{# HTML.escape }}
{{# items }}
{{ name }}
{{/}}
{{/ HTML.escape }}
See also javascript.escape, URL.escape
This filter returns its argument, capitalized: the first character from each word is changed to its corresponding uppercase value, and all remaining characters set to their corresponding lowercase values.
{{ capitalized(firstName) }} {{ capitalized(lastName) }}
See also lowercase, uppercase.
This filter is true if and only if its argument is "blank", that is to say nil, null, empty (empty string or empty enumerable), or a string only made of white spaces.
{{# isBlank(name) }}
Blank name
{{^}}
{{name}}
{{/}}
See also isEmpty.
This filter is true if and only if its argument is "empty", that is to say nil, null, or empty (empty string or empty enumerable).
{{# isEmpty(name) }}
No name
{{^}}
{{name}}
{{/}}
See also isBlank.
As a filter, javascript.escape
outputs a Javascript and JSON-savvy string:
<script type="text/javascript">
var name = "{{ javascript.escape(name) }}";
</script>
As a rendering object, javascript.escape
escapes all inner variable tags in a section:
<script type="text/javascript">
{{# javascript.escape }}
var firstName = "{{ firstName }}";
var lastName = "{{ lastName }}";
{{/ javascript.escape }}
</script>
Variable tags buried inside inner sections are escaped as well, so that you can render loop and conditional sections:
<script type="text/javascript">
{{# javascript.escape }}
var firstName = {{# firstName }}"{{ firstName }}"{{^}}null{{/}};
var lastName = {{# lastName }}"{{ lastName }}"{{^}}null{{/}};
{{/ javascript.escape }}
</script>
See also HTML.escape, URL.escape
As a filter, localize
outputs a string looked in the Localizable.string table of the main bundle:
{{ localize(greeting) }}
This would render Bonjour
, given Hello
as a greeting, and a French localization for Hello
.
As a rendering object, localize
outputs the localization of a full section:
{{# localize }}Hello{{/ localize }}
This would render Bonjour
, given a French localization for Hello
in the Localizable.string table of the main bundle.
Warning: HTML-escaping is done as usual: you localize template snippets that are HTML chunks. There is no escaping.
When looking for the localized string, GRMustache replaces all variable tags with "%@":
{{# localize }}Hello {{name}}{{/ localize }}
This would render Bonjour Arthur
, given a French localization for Hello %@
in the Localizable.string table of the main bundle. [NSString stringWithFormat:]
is used for the final interpolation.
Warning 1: HTML-escaping is done as usual: you localize template snippets that are HTML chunks. There is no escaping, but for {{name}}
.
Warning 2: because of the invocation of stringWithFormat:
, make sure your localized strings escape their percents. {{# localize }}%:{{name}}{{/ localize }}
will render fine as long as you provide a localization for %%:%@
.
You can embed conditional sections inside:
{{# localize }}Hello {{#name}}{{name}}{{^}}you{{/}}{{/ localize }}
Depending on the name, this would render Bonjour Arthur
or Bonjour toi
, given French localizations for both Hello %@
and Hello you
.
The localize
helper is based on the GRMustacheLocalizer class. You can create your own, and localize from a specific localization table from a specific bundle:
// Will localize from the given string file from the given bundle:
GRMustacheLocalizer *localizer = [[GRMustacheLocalizer alloc] initWithBundle:... tableName:...];
id data = @{
// With the `localize` key, this localizer overrides the default one:
@"localize": localizer,
...
};
NSString *rendering = [GRMustacheTemplate renderObject:data from...];
This filter returns a lowercased representation of its argument.
{{ lowercase(name) }}
See also capitalized, uppercase.
This filter returns a uppercased representation of its argument.
{{ uppercase(name) }}
See also lowercase, uppercase.
As a filter, URL.escape
returns its argument, percent-escaped.
<a href="http://google.com?q={{ URL.escape(query) }}">
As a rendering object, URL.escape
escapes all inner variable tags in a section:
{{# URL.escape }}
<a href="http://google.com?q={{ query }}&hl={{ language }}">
{{/ URL.escape }}
Variable tags buried inside inner sections are escaped as well, so that you can render loop and conditional sections:
{{# URL.escape }}
<a href="http://google.com?q={{ query }}{{#language}}&hl={{ language }}{{/language}}">
{{/ URL.escape }}
See also HTML.escape, javascript.escape
All items of the standard library are built using public APIs: check the code for inspiration: