Interpolation in angular is a technique used to dynamically generate content based on data or variables. It is a way of injecting data into templates using a special syntax.
In Angular, interpolation is achieved by wrapping a variable or expression
in double curly braces {{ }}.
For example:
If you have a variable name defined in your component, you can display its value in the template using interpolation as follows:
<p>Hello, {{name}}!</p>
If the value of the name is "zaheer", the above code will render as:
<p>Hello, John!</p>
Angular supports expressions inside the double curly braces as well. This means you can perform arithmetic operations or call functions and display their results in the template using interpolation. For example:
Interpolation is a powerful feature of Angular that makes it easy to create dynamic and responsive applications.
Examples of how interpolation can be used in Angular:
Displaying Component Properties:
One common use case for interpolation is to display component properties in the template.
Let's say we have a component with a property called message.
We can use interpolation to display the value of the message in the template like this:
<p>{{ message }}</p>
Performing String Concatenation:
Interpolation can also be used to concatenate strings in the template. For example,
let's say we have two properties in our component, firstName, and lastName.
We can use interpolation to combine these two properties into a single string in the template like this:
<p>{{ firstName + ' ' + lastName }}</p>
Evaluating Expressions:
In addition to displaying properties and concatenating strings, interpolation can also be used to evaluate expressions in the template.
For example:
Let's say we have a component with a property called count.
We can use interpolation to display the result of an expression that doubles the value of the count like this:
<p>{{ count * 2 }}</p>
Conditionally Displaying Content:
Interpolation can also be used to conditionally display content in the template using the ternary operator. For example, let's say we have a component with a property called isLoggedIn. We can use interpolation to display a different message depending on whether the user is logged in or not like this:
<p>{{ isLoggedIn ? 'Welcome back!' :
'Please log in.' }}</p>
Using Template Variables:
In addition to displaying component properties and evaluating expressions, interpolation can also be used with template variables. Template variables allow you to reference elements in your template and perform actions on them.
For example:
Let's say we have an input element in our template and we want to reference its value in our component. We can use a template variable to achieve this:
<input #myInput type="text">
<p>{{ myInput.value }}</p>
In the above example, we've created a template variable called myInput that references the input element. We can then use interpolation to display the value of the input element's value property in the template.
Displaying Arrays:
Interpolation can also be used to display arrays in the template. Let's say we have an array of numbers in our component.
We can use interpolation to display each number in the array using the *ngFor directive:
<ul>
<li *ngFor="let number of numbers">
{{ number }}</li>
</ul>
In the above example, we're using the *ngFor directive to loop over the numbers array and
display each number in a list item using interpolation.
Using Pipes:
You can use pipes with interpolation to format and transform data before displaying it in the template. For example:
Let's say we have a component with a property called price that contains a number. We can use the currency pipe to format the price as a currency value in the template like this:
<p>{{ price | currency }}</p>