I am trying to learn AngularJs 2 using free video tutorials from scotch.io . I followed most of the parts without too much trouble. But I can not handle the transfer of data from one component to another.
There is app.component.html that lists user profiles. When a user clicks on a user’s link, he should show a text input where the user can change the name.
Here is app.component.html
<header>
<nav class="navbar navbar-inverse">
<div class="navbar-header">
<a href="/" class="navbar-brand">My Angular 2 App</a>
</div>
</nav>
<main>
<div class="row">
<div class="col-sm-4">
<div *ngIf="user_list">
<ul class="list-group users-list" >
<li class="list-group-item" *ngFor="let user of user_list"
(click)="selectUser(user)"
[class.active] = "user == active_user">{{user.name}}</li>
</ul>
</div>
</div>
<div class="col-sm-8">
<user-profile [user] = "active_user"></user-profile>
<div class="jumbotron gocrazy" *ngIf="!active_user">
<span class="glyphicon glyphicon-hand-left"></span>
<h2>Choose a user from the left menu </h2>
</div>
</div>
</div>
</main>
<footer class="text-center">
Copyright © 2016
</footer>
And this is the user-profile.component.ts file .
import {Component, Input} from '@angular/core';
import {User} from '../shared/model/user';
@Component({
selector : 'user-profile',
template : `
<div class="jumbotron gocrazy" *ngIf="user">
<h1>Welcome to our app</h1>
<p>{{user.name}}</p>
<p>{{message}}</p>
<input class="form-control" [(ngModel)] = "user.name" />
</div>
`
})
export class UserProfileComponent{
@Input() user : User;
}
And this is the app.component.ts file .
import {Component} from '@angular/core';
import {User} from './shared/model/user';
@Component({
selector: 'my-app',
templateUrl: './app/app.component.html',
styleUrls : ['./app/app.component.css']
})
export class AppComponent {
message : string = "Hello, How are you?";
user_list : User[] =[
{
name : "Thilini Weerasooriya",
age : 27,
id : 2
},
{
name : "Aurelia",
age : 23,
id : 2
}];
active_user : User;
selectUser(user){
this.active_user = user;
}
}
And here is the app.module.ts file .
import {NgModule} from '@angular/core';
import {BrowserModule} from '@angular/platform-browser';
import {FormsModule} from '@angular/forms';
import {AppComponent} from './app.component';
import {UserProfileComponent} from './users/user-profile.component';
@NgModule({
imports : [BrowserModule, FormsModule],
declarations : [AppComponent, UserProfileComponent],
bootstrap : [AppComponent, UserProfileComponent]
})
export class AppModule{}
And the folder structure is as follows.

And I do not get any errors.

, , Angular TypeScript. , .
!