Overview
These are all the folders and files the Angular CLI created for you. This is your entire Angular project.
Project dependencies
One of the most important files is Package.json which is your dependency configuration file.
Here you can see all the dependencies of your project like Angular 6 and these are third-party packages your project needs to run correctly.
All devDependencies are only required for development.1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48{
"name": "my-app",
"version": "0.0.0",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true,
"dependencies": {
"@angular/animations": "^6.1.0",
"@angular/common": "^6.1.0",
"@angular/compiler": "^6.1.0",
"@angular/core": "^6.1.0",
"@angular/forms": "^6.1.0",
"@angular/http": "^6.1.0",
"@angular/platform-browser": "^6.1.0",
"@angular/platform-browser-dynamic": "^6.1.0",
"@angular/router": "^6.1.0",
"core-js": "^2.5.4",
"rxjs": "^6.0.0",
"zone.js": "~0.8.26"
},
"devDependencies": {
"@angular-devkit/build-angular": "~0.7.0",
"@angular/cli": "~6.1.5",
"@angular/compiler-cli": "^6.1.0",
"@angular/language-service": "^6.1.0",
"@types/jasmine": "~2.8.6",
"@types/jasminewd2": "~2.0.3",
"@types/node": "~8.9.4",
"codelyzer": "~4.2.1",
"jasmine-core": "~2.99.1",
"jasmine-spec-reporter": "~4.2.1",
"karma": "~1.7.1",
"karma-chrome-launcher": "~2.2.0",
"karma-coverage-istanbul-reporter": "~2.0.0",
"karma-jasmine": "~1.1.1",
"karma-jasmine-html-reporter": "^0.2.2",
"protractor": "~5.4.0",
"ts-node": "~5.0.1",
"tslint": "~5.9.1",
"typescript": "~2.7.2"
}
}
Index page
The Index page described in app.component.html
of $Root/src/app
.(Actually, Index page defined in index.html
of $Root
directory, and app.component.html
inject by app.component.ts
with app-root
tag which will talk in the future)1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19<!--The content below is only a placeholder and can be replaced.-->
<div style="text-align:center">
<h1>
Welcome to {{ title }}!
</h1>
<img width="300" alt="Angular Logo" src="">
</div>
<h2>Here are some links to help you start: </h2>
<ul>
<li>
<h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2>
</li>
<li>
<h2><a target="_blank" rel="noopener" href="https://github.com/angular/angular-cli/wiki">CLI Documentation</a></h2>
</li>
<li>
<h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2>
</li>
</ul>
And the Index page shows as below:
Modify this block:1
2
3<h1>
Welcome to {{ title }}!
</h1>
to1
2
3<h1>
This is my first App!
</h1>
Then Index page content changed to:
You may see a special code in previous block as Edit Application
, this is dynamic combination with the value in TypeScript
files. Angular allows us to mix static HTML code and dynamic things we want to output in that code.
The title
defined in app.component.ts
file as:1
2
3
4
5
6
7
8
9
10
11import { Component } from '@angular/core';
({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'my-app';
}
Now, let us change the title value from my-app
to First Application
and insert another variable user
as below:1
2
3
4export class AppComponent {
title = 'First Application';
user = 'Vince'
}
And update the html block as1
2
3<h1>
{{ user }}'s {{ title }}!
</h1>
The index page presents like:
Data binding
We use curly braces for data binding - like Edit Application
; this process is called interpolation. We have already seen in our previous examples how we declared the value to the variable title and the same is printed in the browser.
The variable in the app.component.html
file is referred as Edit Application
and the value of title is initialized in the app.component.ts
file and in app.component.html
, the value is displayed.
With data binding feature, we could build more fancy webs by update the app.module.ts
as:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { AppComponent } from './app.component';
({
declarations: [
AppComponent
],
imports: [
BrowserModule,
FormsModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
Update app.component.html
as:1
2
3
4
5
6
7
8
9<div style="text-align:center">
<h1>
{{ user }}'s {{ title }}!
</h1>
<p> User </p> <br>
<input type = "text" [(ngModel)] = "user">
<p> Title </p> <br>
<input type = "text" [(ngModel)] = "title">
</div>
Then the index page changed to:
The content will sync with input simultaneously.