loio |
---|
5cff8d1c3fb84c5db7a00f2daca125af |
view on: demo kit nightly build | demo kit latest release
An expression binding lets you display a calculated value on the screen, which is derived from values found in a model object. This feature allows you to insert simple formatting or calculations directly into the data binding string. In this example, we're changing the color of the price depending on whether it's above or below a certain threshold. The threshold value is stored in the JSON model.
Prices are color-coded depending on a selected threshold
You can view and download all files in the Demo Kit at Data Binding - Step 14.
-
Add a new property called
priceThreshold
with a value of 20 to thedata.json
file.webapp/model/data.json
{ "firstName": "Harry", "lastName": "Hawk", "enabled": true, "address": { "street": "Dietmar-Hopp-Allee 16", "city": "Walldorf", "zip": "69190", "country": "Germany" }, "salesAmount": 12345.6789, "priceThreshold": 20, "currencyCode": "EUR" }
-
In the
App.view.xml file
, add a newnumberState
property to theObjectListItem
element within theList
. The value of this property is an expression that gets evaluated for each item. The expression compares each invoice value against the price threshold and returns a number state based on the result.webapp/view/App.view.xml
... <Panel headerText="{i18n>panel3HeaderText}" class="sapUiResponsiveMargin" width="auto"> <List headerText="{i18n>productListTitle}" items="{products>/Products}"> <items> <ObjectListItem press=".onItemSelected" type="Active" title="{products>ProductName}" number="{ parts: [ {path: 'products>UnitPrice'}, {path: '/currencyCode'} ], type: 'sap.ui.model.type.Currency', formatOptions: { showMeasure: false } }" numberUnit="{/currencyCode}" numberState="{= ${products>UnitPrice} > ${/priceThreshold} ? 'Error' : 'Success' }"> <attributes> <ObjectAttribute text="{products>QuantityPerUnit}"/> <ObjectAttribute title="{i18n>stockValue}" text="{ parts: [ {path: 'products>UnitPrice'}, {path: 'products>UnitsInStock'}, {path: '/currencyCode'} ], formatter: '.formatStockValue' }"/> </attributes> </ObjectListItem> </items> </List> </Panel> ...
By binding an expression to the numberState
property, the error status (color) of the price field changes depending on the invoice value.
Consider the following two expressions:
-
numberState="{= ${products>UnitPrice} > ${/priceThreshold} ? 'Error' : 'Success' }"
-
numberState="{= ${products>UnitPrice} <= ${/priceThreshold} ? 'Success' : 'Error' }"
Can you see why one of these expressions works, and the other doesn't?
Logically, both expressions are identical. However, the first one works, and the second one doesn't: it only produces an empty screen and an "Invalid XML" message in the browser's console. So, what's happening here?
To understand the situation, you need to know how XML files are parsed.
When an XML file is parsed, certain characters have a special (high-priority) meaning to the XML parser. When these characters are encountered, they're always interpreted to be part of the XML definition itself, and not as part of any other content within the XML document.
The XML parser always interprets one of these high-priority characters (in this case, a less-than (<
) character) as the start of a new XML tag. This happens regardless of any other meaning that character might have within the context of the expression. This is known as a syntax collision.
In our case, the collision occurs between the syntax of XML and the syntax of the JavaScript-like expression language used by OpenUI5.
Therefore, this statement fails because the less-than character is interpreted as the start of an XML tag: numberState="{= ${products>UnitPrice} <= ${/priceThreshold} ? 'Success' : 'Error' }"
You can avoid this problem in one of two ways:
-
Reverse the logic of the condition (use "greater than or equal to" instead of "less than")
-
Use the escaped value for the less-than character:
numberState="{= ${products>UnitPrice} <= ${/priceThreshold} ? 'Success' : 'Error' }"
Since using an escaped character is not so easy to read, we recommend reversing the logic of the condition and using a greater-than character instead.
The ampersand (&
) character also has a high-priority meaning to the XML parser. This character always means "The start of an escaped character". So, if you'd like to use the Boolean AND
operator (&&
) in a condition, you must escape both ampersand characters (&&
).
Parent topic:Data Binding Tutorial
Previous:Step 15: Aggregation Binding Using a Factory Function
Related Information