> For the complete documentation index, see [llms.txt](https://docs.aurelia.io/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://docs.aurelia.io/examples/examples/binding-and-templating.md).

# Binding & Templating

## Looping with repeat.for

Aurelia provides a `repeat.for` attribute that allows you to loop over data inside of your views. Think of `repeat.for` as the equivalent of a traditional for loop in Javascript. Common scenarios might include loop over an array of products for an online store or options for a select dropdown.

You will find numerous working code examples below showcasing how you can work with collections of data in Aurelia.

### Looping over an array of strings

In the following example, we loop over an array inside of our view model called `items` and display the values in an unordered list. Notice how we use `repeat.for` on our list item? This tells Aurelia that for every value it finds, populate `item` with its value.

This type of functionality is convenient for situations where you want to display simple string values or populate select dropdowns where you only need the display value.

{% embed url="<https://stackblitz.com/edit/aurelia-repeat-array-of-strings?embed=1&file=my-app.html>" %}

### Looping over an array of objects

More commonly when working with an array of data, you will be working with an array of objects. You still loop over the array as we did in the previous example, however, we treat the populated `item` variable as an object, referencing the property names in view.

{% embed url="<https://stackblitz.com/edit/aurelia-repeat-array-of-strings-sxz6uq?embed=1&file=my-app.html>" %}

### Looping with numeric ranges

Sometimes you might want to display a list of values in successive order, a range of numbers of 1 to 10. The repeater allows you to do this with ease. In the following example, there is nothing defined inside of the view model, just the view. All we did was write `repeat.for="i of 10"` and then displayed the value, counting it down with each iteration.

{% embed url="<https://stackblitz.com/edit/aurelia-repeat-range?embed=1&file=my-app.html>" %}

## Expression syntax

Aurelia's expression parser implements a subset of [ECMAScript Expressions](https://tc39.github.io/ecma262/#sec-ecmascript-language-expressions). For the features that are supported, you can typically expect the JavaScript in your view to work the same way as it would in your view model, or in the browser console. In addition, there are two adjustments:

* The Ampersand `&` represents a `BindingBehavior` (instead of Bitwise AND)
* The Bar `|` represents a `ValueConverter` (instead of a Bitwise OR)

Non-expression syntax (statements, declarations, function and class definitions) is not supported.

As an overview of various expressions that are possible, the following list is for illustrative purposes and not exhaustive (and not necessarily recommended, either), but should give you a fairly good idea of what you can do.

### Primary Expressions

#### Identifiers

* `foo` - The `foo` variable in the current view-model
* `ßɑṙ` - The `ßɑṙ` variable in the current view-model

{% hint style="info" %}
**Info**

non-ASCII characters in the [Latin](https://en.wikipedia.org/wiki/Latin_script_in_Unicode#Table_of_characters) script are supported. This script contains 1,350 characters covering the vast majority of languages. Other [Non-BMP characters / Surrogate Pairs](https://en.wikipedia.org/wiki/Plane_\(Unicode) are not supported.
{% endhint %}

#### Identifiers with special meaning in Aurelia

* `$this` - The current view-model
* `$parent` - The parent view-model

#### Primitive literals

* `true` - The literal value `true`
* `false` - The literal value `false`
* `null` - The literal value `null`
* `undefined` - The literal value `undefined`

#### String literals and escape sequences

* `'foo'` or `"foo"` - The literal string `foo`
* `'\n'` - The literal string `[NEWLINE]`
* `'\t'` - The literal string `[TAB]`
* `'\''` - The literal string `'`
* `'\\'` - The literal string `\`
* `'\\n'` - The literal string
* `'\u0061'` - The literal string `a`

{% hint style="warning" %}
**Warning**

Unsupported string literals include `'\x61'` (2-point hex escape), `'\u{61}'` or `'\u{000061}'` (n-point braced unicode escape), and Non-BMP characters and Surrogate Pairs.
{% endhint %}

### Template literals

* `` `foo` `` - Equivalent to `'foo'`
* `` `foo\${bar}baz\${qux}quux` `` - Equivalent to `'foo'+bar+'baz'+qux+'quux'`

#### Numeric literals

* `42` - The literal number `42`
* `42.` or `42.0` - The literal number `42.0`
* `.42` or `0.42` - The literal number `0.42`
* `42.3` - The literal number `42.3`
* `10e3` or `10E3` - The literal number `1000`

{% hint style="warning" %}
**Warning**

Unsupported numeric literals include `0b01` (binary integer literal), `0o07` (octal integer literal), and `0x0F` (hex integer literal).
{% endhint %}

### Array literals

* `[]` - An empty array
* `[1,2,3]` - An array containing the literal numbers `1`, `2` and `3`
* `[foo, bar]` - An array containing the variables `foo` and `bar`
* `[[]]` - An array containing an empty array

{% hint style="warning" %}
**Warning**

Unsupported array literals include `[,]` - [Elision](https://tc39.github.io/ecma262/#prod-Elision)
{% endhint %}

### Object literals

* `{}` - An empty object
* `{foo}` or `{foo,bar}` - ES6 shorthand notation, equivalent to `{'foo':foo}` or `{'foo':foo,'bar':bar}`
* `{42:42}` - Equivalent to `{'42':42}`

{% hint style="warning" %}
**Warning**

Unsupported object literals include `{[foo]: bar}` or `{['foo']: bar}` (computed property names).
{% endhint %}

### Unary Expressions

**`foo` here represents any valid primary expression or unary expression.**

* `+foo` or `+1` - Equivalent to `foo` or `1` (the `+` unary operator is always ignored)
* `-foo` or `-1` - Equivalent to `0-foo` or `0-1`
* `!foo` - Negates `foo`
* `typeof foo` - Returns the primitive type name of `foo`
* `void foo` - Evaluates `foo` and returns `undefined`

{% hint style="warning" %}
**Warning**

Unary increment (`++foo` or `foo++`), decrement (`--foo` or `foo--`), bitwise (`~`), `delete`, `await` and `yield` operators are not supported.
{% endhint %}

### Binary Expressions (from highest to lowest precedence)

**`a` and `b` here represent any valid primary, unary or binary expression.**

* `a*b` or `a/b` or `a%b` - Multiplicative
* `a+b` or `a-b` - Additive
* `a<b` or `a>b` or `a<=b` or `a>=b` or `a in b` or `a instanceof b` - Relational
* `a==b` or `a!=b` or `a===b` or `a!==b` - Equality
* `a&&b` - Logical AND
* `a||b` - Logical OR

{% hint style="warning" %}
**Warning**

Exponentiation (`a**b`) and bitwise operators are not supported.
{% endhint %}

### Conditional Expressions

**`foo` etc here represent any valid primary, unary, binary or conditional expression.**

* `foo ? bar : baz`
* `foo ? bar : baz ? qux : quux`

### Assignment Expressions

**`foo` here must be an assignable expression (a simple accessor, a member accessor or an indexed member accessor). `bar` can any valid primary, unary, binary, conditional or assignment expression.**

* `foo = bar`
* `foo = bar = baz`

### Lambda Expressions

Lambda expressions can be used to call methods like `Array#filter`, `Array#sort`, but can also be passed in as an argument to a method on your ViewModel or even invoked as an IIFE.

* `() => 42`
* `x => x.name` (e.g. `${items.map(x => x.name).join(', ')}`)
* `(...args) => args.join(', ')`
* `(a => b => c => a + b + c)(1)(2)(3)` (renders '6')
* `items.reduce((sum, x) => sum + x, 0)`

{% hint style="warning" %}
**Warning**

* Wrapping the expression body in braces (`(a, b) => { ... }`) is not supported.
* Default parameters (`(a = 42) => ...`) are not supported.
* Destructuring parameters (`({a}) => ...` or `([a]) => ...`) is not supported.
  {% endhint %}

### Member and Call Expressions

Member expressions with special meaning in Aurelia:

* `$parent.foo` - Access the `foo` variable in the parent view-model
* `$parent.$parent.foo` - Access the `foo` variable in the parent's parent view-model
* `$this` - Access the current view-model (equivalent to simply `this` inside the view-model if it's an ES class)

Normal member and call expressions:

**`foo` here represents any valid member, call, assignment, conditional, binary, unary or primary expression (provided the expression as a whole is also valid JavaScript).**

* `foo.bar` - Member accessor
* `foo['bar']` - Keyed member accessor
* `foo()` - Function call
* `foo.bar()` - Member function call
* `foo['bar']()` - Keyed member function call

Tagged template literals:

**`foo` here should be a function that can be called. The string parts of the template are passed as an array to the first argument and the expression parts are passed as consecutive arguments.**

* `` foo`bar` `` - Equivalent to `foo(['bar'])`
* `` foo`bar\${baz}qux` `` - Equivalent to `foo(['bar','qux'], baz)`
* `` foo`bar\${baz}qux\${quux}corge` `` - Equivalent to `foo(['bar','qux','corge'],baz,quux)`
* `` foo`\${bar}\${baz}\${qux}` `` - Equivalent to `foo(['','','',''],bar,baz,qux)`

### Binding Behaviors and Value Converters

These are not considered to be a part of normal expressions and must always come at the end of an expression (though multiple can be chained). Furthermore, BindingBehaviors must come after ValueConverters. (note: BindingBehavior and ValueConverter are abbreviated to BB and VC for readability)

Valid BB expressions:

* `foo & bar & baz` - Applies the BB `bar` to the variable `foo`, and then applies the BB `baz` to the result of that.
* `foo & bar:'baz'` - Applies the BB `bar` to the variable `foo`, and passes the literal string `'baz'` as an argument to the BB
* `foo & bar:baz:qux` - Applies the BB `bar` to the variable `foo`, and passes the variables `baz` and `qux` as arguments to the BB
* `'foo' & bar` - Applies the BB `bar` to the literal string `'foo'`

Valid VC expressions (likewise):

* `foo | bar | baz`
* `foo | bar:'baz'`
* `foo | bar:baz:qux`
* `'foo' | bar`

Combined BB and VC expressions:

* `foo | bar & baz`
* `foo | bar:42:43 & baz:'qux':'quux'`
* `foo | bar | baz & qux & quux`

Invalid combined BB and VC expressions (BB must come at the end):

* `foo & bar | baz`
* `foo | bar & baz | qux`


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.aurelia.io/examples/examples/binding-and-templating.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
