Skip to content

Latest commit

 

History

History
116 lines (71 loc) · 3.7 KB

Keep_Your_Views_Short_and_Simple_b0d7db7.md

File metadata and controls

116 lines (71 loc) · 3.7 KB
loio
b0d7db7930f64b9399dc2b4979293873

Keep Your Views Short and Simple

The view part of your app reflects what users can see and interact with. You should use a suitable set of UI controls that match your scenario and keep things simple.


Most bread-and-butter controls are located in the sap.m namespace, which makes it the perfect default namespace. If you want to add other controls and layouts, you can define an additional namespace. For your own namespaces, you should keep the alias short and simple as well. You will typically use it in many places, and a short alias keeps your code tidy.

<mvc:View
	xmlns="sap.m"
	xmls:l="sap.ui.layout"
	xmlns:mvc="sap.ui.core.mvc">
	<App>
		<Page>
			<l:HorizontalLayout>
			...

It's easy to save a few bytes and make your code a lot cleaner:

  • Don't define properties that are set to their default values.

  • Remove unused namespace aliases.

  • Omit the content or items tag for controls that define default aggregations.

  • Use self-closing XML tags for controls that don't define any aggregations.

Tip:

Samples may contain more code that you actually need. When you copy code from a sample, it's best to remove all properties that won't be used in your views.

<SearchField change=".onSearch"/>
<List items="{/Products}" headerText="Search Results">
	<StandardListItem title="{Name}"/>
</List>
</Panel>

If you have bound aggregations, Avoid using complex or nested controls. Remember: The template below will be repeated for every entity in your data. If the template is more complex than necessary, this may lead to performance issues at runtime and slow down your app.

<List
	items={/Products}>
	<StandardListItem
		title="{Name}"
		description="{Text}"/>

Things may get a little messy as your app is growing with your requirements. Therefore, name your views semantically. If a view is getting too "heavy", you should outsource parts of it to a separate view. With XML fragments, you can flexibly reuse parts of your UI elsewhere.

<App>
	<Page>
		<mvc:XMLView viewName="EmployeList"/>
	</Page>
</App>

OpenUI5 offers a huge collection of feature-rich UI controls, often giving you multiple implementation choices.

Aim for the simplest possible pattern to implement your use case. For more information, see the Samples, and filter for "layout".