To build semantic HTML templates, OpenUI5 uses handlebars. You can either use standard expressions and helpers together for the context of a template instance, or you can use the custom helpers for handlebars provided by OpenUI5, which you can use together with the OpenUI5 models.
The HTML templating concept in OpenUI5 enables you to bind texts against properties in the model. If the property in the model changes, the text is updated accordingly. You can create and bind the value DOM elements including their DOM attributes. For input DOM elements like INPUT, TEXTAREA or SELECT, OpenUI5 establishes a two-way binding: On change of the DOM element value the model is updated if the value is bound against a OpenUI5 model. You can also define controls in the template similar to the declarative support but in handlebars helper notation.
To get started with HTML templating, you must comply with the following requirements:
Example:
#!js
<div id="myControlTemplate" data-type="text/x-handlebars-template">
    
        <h3>Control Template (using "control" expression)</h3>
        {{control sap-ui-type="sap.ui.commons.Label" design="Bold" text="{/title}"}}
        <ul>
        {{#each path="/persons"}}
            <li>{{control sap-ui-type="sap.ui.commons.TextView" text="{lastName}, {firstName}"}}</li>
        {{/each}}
        </ul>
    
    </div>#!js // register all available templates in the document sap.ui.template();
OpenUI5 looks up all DOM elements with a data-type attribute and checks if the respective data type is supported. If yes, OpenUI5 creates a new instance of sap.ui.core.tmpl.Template which represents the raw template and contains the markup of the template that is later used by the templating engine to create the final HTML markup. You can use the placeAt method to add the template instance to the DOM. If you define a template in the head with a SCRIPT tag, for example, OpenUI5 only creates the template instance. For inline templates, this instance is then placed at the same location of the document.
You can use the factory function sap.ui.template to parse all templates defined in SCRIPT tags in the head or in DIV tags in the body. If you do not specify a parameter, OpenUI5 templating looks up all available templates.