If properly setup, Owl can translate all rendered templates. To do so, it needs a translate function, which takes a string and returns a string.
For example:
const translations = {
hello: "bonjour",
yes: "oui",
no: "non",
};
const translateFn = (str) => translations[str] || str;
const app = new App(Root, { templates, tranaslateFn });
// ...
See the app configuration page for more info on how to configure an Owl application.
Once setup, all rendered templates will be translated using translateFn
:
- each text node will be replaced with its translation,
- each of the following attribute values will be translated as well:
title
,placeholder
,label
andalt
, - translating text nodes can be disabled with the special attribute
t-translation
, if its value isoff
.
So, with the above translateFn
, the following templates:
<div>hello</div>
<div t-translation="off">hello</div>
<div>Are you sure?</div>
<input placeholder="hello" other="yes"/>
will be rendered as:
<div>bonjour</div>
<div>hello</div>
<div>Are you sure?</div>
<input placeholder="bonjour" other="yes"/>
Note that the translation is done during the compilation of the template, not when it is rendered.
In some case, it is useful to be able to extend the list of translatable attributes.
For example, one may want to also translate data-title
attributes. To do that,
we can define additional attributes with the translatableAttributes
option:
const app = new App(Root, { templates, tranaslateFn, translatableAttributes: ["data-title"] });
// ...
It is also possible to remove an attribute from the default list by prefixing it with -
:
const app = new App(Root, {
templates,
tranaslateFn,
translatableAttributes: ["data-title", "-title"],
});
// data-title attribute will be translated, but not title attribute...