Now, you are going to add the todo-list itself to the component app-root
. Find the root file, src/app/app.component.ts
. Then, you need to perform two steps. First, go to AppComponent
class, open a new line right after private title: string = 'My Todos';
and put in the list of items for ToDo list as an array of JSON-like objects for each item. At the beginning, each item only contains a title:
private todoList = [
{title: 'install NodeJS'},
{title: 'install Angular CLI'},
{title: 'create new app'},
{title: 'serve app'},
{title: 'develop app'},
{title: 'deploy app'},
];
Putting info (resources) right inside your code is called hardcoding and considered an especially bad practice. Indeed, you will move the item list to a service file later on. But let's advance step-by-step, so, defining items this way is okay for now.
Now, you have to tell the browser to display those items. For this, you will use the Angular built-in directive, *ngFor
. It works as an enhanced loop in Java. *
is a semantic though necessary notation which causes Angular to use the current element as template to render the loop.
Insert the loop right after <todo-input></todo-input>
, this way:
<ul>
<li *ngFor="let item of todoList">
{{ item.title }}
</li>
</ul>
This means "go over all items of todoList array defined below, and print out an unnumbered list which contains item titles". While looping over the todoList
, each item is assigned to the variable item
, and we can use this variable inside the element and its children.
Directives are pieces of logic (written as classes) that can be attached to elements and components. They are used to change the display or the behavior of the element. Angular comes with some built-in directives.
As we saw, the ngFor
directive modifies the template in run-time by repeating the element it's called on and its content. Another directive, for example, is ngIf
, which receives a Boolean expression. Only if the expression is true Angular renders the element and its content. It also needs *
because it changes the template in run-time. For example:
<h1 *ngIf="userLoggedIn">Welcome!</h1>
userLoggedIn
is a member of the component which has a true or false value. If it's true, the element will be displayed. If false, the element will not exist on the DOM.
There are other directives in Angular which are not structural (and are used without the *
). For example ngStyle and ngClass.