AngularJS 4(二)【模版語法,元件】
模板語法(Template Syntax)
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
template: '<h1>{{title}}</h1>',
})
export class AppComponent {
title = 'Welcome to Anglar';
name = 'Tom';
age = 22;
id = '001';
className = 'class1';
actived = true;
mySize = 100;
}
插值表示式
把文字內容繫結到插值字串(如”Hello Seabiscuit”)
<h1>{{title}}</h1>
屬性繫結
- 元素直接繫結常量:
<input type="text" title="form">
- 元素自身屬性繫結變數:
<input type="text" [name]="name" [id]="id" >
- 元素自定義屬性繫結:
<div [attr.age]="age"></div>
元素類名 class 繫結
- 繫結樣式名稱為變數
<div [class]="className"></div>
- 根據表示式來決定 className 出不出現在元素上
<div [class.className]="1 == 1"></div>
元素內聯樣式繫結:
<div [style.width.px]="mySize" [style.color]="'red'"></div>
元素事件繫結:
<input type="button" value="confirm" (click)="confirm($event, args)"/>
雙向繫結
該指令用於表單元素,所以在使用的時候要在根模組中 ./src/app/app.module.ts
新增表單模組 FormsModule
import { BrowserModule } from '@angular/platform-browser';
import {FormsModule} from '@angular/forms';
@NgModule({
imports: [FormsModule, BrowserModule]
})
<input type="text" [(ngModel)]="name" />
本地變數
<h1>{{name.value}}</h1>
<input type="text" [(ngModel)]="name" #name/>
建立簡單的元件
建立檔案
在./src/app
目錄下手動建立或者在 Angular-CLI 中用命令
ng g c [component-name] -it -is # 表示新建元件,該元件使用內聯模板和內聯樣式
執行上面命令後會在./src/app
目錄下自動建立對應的元件目錄和元件檔案,同時會修改src/app/app.module.ts
檔案,將新建的元件新增到@NgModule
的declarations
陣列中。編寫元件程式碼
//載入元件裝飾器
import { Component } from '@angular/core';
//@Component裝飾器為元件提供了Angular後設資料。
@Component({
selector: 'app-root', //用來渲染元件內容的選擇器
templateUrl: './app.component.html',//載入 html
template:'<h1>{{title}}</h1>',
styleUrls: ['./app.component.css'] //載入 css
styles: ['*{padding: 0; margin: 0;}']
})
//總是export這個元件類,因為你必然會在別處import它。
export class AppComponent {
title = 'Tour of Heroes'; //定義變數
}
3.在根模版 ./src/app.module.ts
中將指令新增到 declarations
陣列當中
import { HeroDetailComponent } from './components/hero-detail/hero-detail.component';
@NgModule({
declarations: [HeroDetailComponent]
})
4.使用元件
<app-root></app-root>
元件模板
在元件裝飾器中用 template
或 templateUrl
來定義元件模板,兩者只能出現一個,如果兩者同時出現,後者會覆蓋前者。
元件樣式
在元件裝飾器中用 styles
或 styleUrls
來定義元件樣式,兩者只能出現一個,如果兩者同時出現,後者會覆蓋前者。
把樣式加入元件有以下幾種方式:
styles
@Component({
selector: 'app-root',
template: `<h1>App</h1>`,
styles: ['h1 { font-weight: normal; }']
})
export class AppComponent {
/* . . . */
}
styleUrls
@Component({
selector: 'app-root',
template: `<h1>App</h1>`,
styleUrls: ['./app.component.css']
})
export class AppComponent {
/* . . . */
}
模板內聯樣式
@Component({
selector: 'app-root',
template: `
<style>
button {
background-color: white;
border: 1px solid #777;
}
</style>
<h3>Controls</h3>
<button (click)="activate()">Activate</button>
`
})
export class AppComponent {
/* . . . */
}
模板中的link標籤
@Component({
selector: 'app-root',
template: `
<link rel="stylesheet" href="assets/app.component.css">
<h3>Team</h3>
<ul>
<li *ngFor="let member of hero.team">
{{member}}
</li>
</ul>
`
})
export class AppComponent {
/* . . . */
}
CSS @imports 語法
@import 'hero-details-box.css';
元件生命週期
指令和元件的例項有一個生命週期:新建、更新和銷燬。 通過實現一個或多個 Angular core庫裡定義的生命週期鉤子介面
每個介面都有唯一的一個鉤子方法,它們的名字是由介面名再加上ng字首構成的。如:OnInit
import { Component, OnChanges, OnInit, DoCheck, OnDestroy } from '@angular/core';
export class AppComponent implements OnChanges, OnInit, DoCheck, OnDestroy {
ngOnChanges(){}
ngOnInit(){}
ngDoCheck(){}
ngOnDestroy(){}
}
OnChanges
- 當
Angular
(重新)設定資料繫結輸入屬性時響應。 該方法接受當前和上一屬性值的SimpleChanges
物件。 - 當被繫結的輸入屬性的值發生變化時呼叫,首次呼叫一定會發生在
ngOnInit()
之前。
OnInit
- 在
Angular
第一次顯示資料繫結和設定指令/元件的輸入屬性之後,初始化指令/元件時觸發。 - 在第一輪
ngOnChanges()
完成之後呼叫,只呼叫一次。 - 在
onDestroy()
後重新渲染後會被呼叫。
AfterContentInit
- 當把內容投影進元件之後呼叫。第一次
ngDoCheck()
之後呼叫,只呼叫一次。 - 只適用於元件。
DoCheck
- 使用
DoCheck
鉤子來檢測那些Angular
自身無法捕獲的變更並採取行動。如引用型別的賦值。 - 給元件賦值同一個物件的時候,不會觸發
OnChanges
,但會觸發DoCheck
。
AfterContentChecked
- 每次完成被投影元件內容的變更檢測之後呼叫。
ngAfterContentInit()
和每次ngDoCheck()
之後呼叫。- 只適用於元件。
OnDestroy
- 當
Angular
每次銷燬指令/元件之前呼叫並清掃。 在這兒反訂閱可觀察物件和分離事件處理器,以防記憶體洩漏。 - 在
Angular
銷燬指令/元件之前呼叫。 - 沒有對應的銷燬後鉤子函式。
AfterViewInit
Angular
會在每次建立了元件的子檢視後呼叫它們。- 可用於監聽子元件載入完成。
AfterViewChecked
Angular
會在每次子檢視修改後會呼叫它們。- 可用於監聽子元件修改完成。
元件通訊
通過 @Input
實現子元件呼叫父元件
父元件定義
import { Component } from '@angular/core';
export class Hero {
id: number;
name: string;
}
const HEROES: Hero[] = [
{ id: 11, name: 'Mr. Nice' },
{ id: 12, name: 'Narco' },
{ id: 13, name: 'Bombasto' },
{ id: 14, name: 'Celeritas' },
{ id: 15, name: 'Magneta' },
{ id: 16, name: 'RubberMan' },
{ id: 17, name: 'Dynama' },
{ id: 18, name: 'Dr IQ' },
{ id: 19, name: 'Magma' },
{ id: 20, name: 'Tornado' }
];
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent{
heroes = HEROES;
currHero: Hero;
selectHero(hero: Hero) {
this.currHero = hero;
}
}
父元件的 template
並在裡面呼叫子元件
<ul class="heroes">
<li *ngFor="let hero of heroes" (click)="selectHero(hero)">
<span class="badge">{{hero.id}}</span>{{hero.name}}
</li>
</ul>
<hero *ngIf="currHero" [currHero]="currHero"></hero>
子元件定義
import { Component, Input } from '@angular/core';
@Component({
selector: 'hero',
templateUrl: './hero.component.html',
styleUrls: ['./hero.component.css']
})
export class HeroComponent{
@Input() currHero: Object;
}
子元件的 template
<div *ngIf="currHero">
<h2>{{currHero.name}} details!</h2>
<div><label>id: </label>{{currHero.id}}</div>
<div>
<label>name: </label>
<input [(ngModel)]="currHero.name" placeholder="name"/>
</div>
</div>
通過 @Output
實現父元件呼叫子元件
子元件暴露一個EventEmitter
屬性,當事件發生時,子元件利用該屬性emits
(向上彈射)事件。父元件繫結到這個事件屬性,並在事件發生時作出迴應。
子元件的EventEmitter
屬性是一個輸出屬性,通常帶有@Output
裝飾器,就像在VoterComponent
中看到的。
父元件定義
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent{
parentEvent(val: Boolean){
console.log(val);
}
}
父元件的 template
並在裡面呼叫子元件
<hero (parentAttr)="parentEvent($event)"></hero>
子元件定義
import { Component, Output } from '@angular/core';
@Component({
selector: 'hero',
templateUrl: './hero.component.html',
styleUrls: ['./hero.component.css']
})
export class HeroComponent{
@Output() parentAttr = new EventEmitter<Boolean>();
childrenEvent(val: Boolean){
this.parentAttr.emit(val);
}
}
子元件的 template
<button (click)="childrenEvent(true)">Agree</button>
父元件與子元件通過本地變數互動
父元件定義
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent{
parentEvent(arg1){
console.log(arg1);
}
}
父元件的 template
並在裡面呼叫子元件
<button (click)="parentEvent(childrenComponent)">Stop</button>
<hero #childrenComponent></hero>
子元件定義
import { Component, Output } from '@angular/core';
@Component({
selector: 'hero',
templateUrl: './hero.component.html',
styleUrls: ['./hero.component.css']
})
export class HeroComponent{
title = "Children Component";
}
通過服務來通訊
相關文章
- AngularJS 4(三)【指令】AngularJS
- AngularJS 4(五)【管道】AngularJS
- AngularJS 4(七)【路由】AngularJS路由
- artTemplate模版引擎的簡潔語法的基本用法
- AngularJS(二、如何用AngularJS建立前端程式碼框架)AngularJS前端框架
- Vue 元件的使用語法Vue元件
- AngularJS 4(一)【搭建環境】AngularJS
- AngularJS 4(四)【HTTP 服務】AngularJSHTTP
- AngularJS 4(六)【依賴注入】AngularJS依賴注入
- ASP.NET MVC下使用AngularJs語言(二):ng-click事件ASP.NETMVCAngularJS事件
- 4- sqoop語法OOP
- AngularJS自定義表單控制元件AngularJS控制元件
- AngularJS學習日記(二)路由AngularJS路由
- Python基礎語法(二)Python
- dockerfile語法小解說(二)Docker
- Dart語言詳解(二)——基本語法Dart
- AngularJS、 Angular 2、Angular 4 的區別AngularJS
- redis系列(二)- 語法與命令Redis
- aardio教程二) 進階語法
- Hive語法及其進階(二)Hive
- Azure Bicep(二)語法簡介
- Azure Terraform(二)語法詳解ORM
- Angularjs——初識AngularJSAngularJS
- N4語法複習(一)
- ES6語法(二) 函式函式
- Flutter學習之Dart語法(二)FlutterDart
- 第二課 Python基礎語法Python
- AngularJs with Webpackv1 升級到 Webpack4AngularJSWeb
- 4、JavaScript進階篇①——基礎語法JavaScript
- Go編譯原理系列4(語法分析)Go編譯原理語法分析
- PL/SQL第二章--基本語法SQL
- awk 語法與內建變數(二)變數
- Vue 3 元件基礎與模板語法詳解Vue元件
- Gradle入門系列(二)——groovy高階語法Gradle
- Kotlin開發之旅《二》—Kotlin的基本語法Kotlin
- 重學ES6基礎語法(二)
- BitBake使用攻略--BitBake的語法知識二
- 模版