欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Angular6學(xué)習(xí)筆記之主從組件

 更新時間:2018年09月05日 14:56:24   作者:wujiayucn  
這篇文章主要介紹了詳解Angular6學(xué)習(xí)筆記之主從組件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

主從組件

繼學(xué)習(xí)筆記6,現(xiàn)在可以在頁面上顯示一個數(shù)組,但是原則上不能將所有特性放在同一個組件中,因為如果將所有特性放在同一個組件中,當(dāng)特性特別多時,組件就變得不好維護(hù)了。所以要將大型組件拆分為多個小型組件,使每一個小型組件集中處理某一個特性任務(wù)或者工作流,而且這樣也便于維護(hù)。

這次要將學(xué)習(xí)筆記6中的查看hero詳情,放置在一個新的,獨立,可復(fù)用的組件中,集中在新的組件管理和維護(hù)hero詳情的信息。

1.創(chuàng)建一個新的組件

使用 Angular CLI 生成一個名叫 hero-detail 的新組件。

wjydeMacBook-Pro:demo wjy$ ng generate component hero-detail
CREATE src/app/hero-detail/hero-detail.component.css (0 bytes)
CREATE src/app/hero-detail/hero-detail.component.html (30 bytes)
CREATE src/app/hero-detail/hero-detail.component.spec.ts (657 bytes)
CREATE src/app/hero-detail/hero-detail.component.ts (288 bytes)
UPDATE src/app/app.module.ts (548 bytes)

這樣就生成了 HeroDetailComponent 組件所需要的文件,并把它聲明在 AppModule 中。

2.編寫 HeroDetailComponent的模版(hero-detail.component.html)

從 HeroesComponent 模板的底部把表示英雄詳情的 HTML 代碼剪切粘貼到所生成的 HeroDetailComponent 模板中。

粘貼過來的html代碼中,有selectHero這個屬性,由于現(xiàn)在我們展示的不僅僅是被選中的hero,而是需要展示的是每一個hero,這個過程相當(dāng)于將HeroDetail這個組件的功能擴(kuò)大化。所以將其更改為:hero , hero-detail.component.html如下:

<div *ngIf="hero">
 <h2>{{hero.name | uppercase}} Details</h2>
 <div><span>id: </span>{{hero.id}}</div>
 <div>
  <label>name:
   <input [(ngModel)]="hero.name" placeholder="name"/>
  </label>
 </div>
 
</div>

因為HeroDetail重的hero是從其他父組件得到。所以hero 屬性必須是一個帶有 @Input() 裝飾器的輸入屬性,因為外部的 HeroesComponent 組件將會綁定到它。

具體步驟:

導(dǎo)入Hero

import { Hero } from '../hero';

導(dǎo)入Input符號

import { Component, OnInit, Input } from '@angular/core';

定義hero

@Input() hero: Hero;

這樣,就對heroDetail的類文件寫好了,heroDetail所做的工作就是:從其他的父組件中接收一個Hero類型的對象,并將它展示出來

3.顯示 HeroDetailComponent

現(xiàn)在有HeroDetail組件顯示每一個Hero的具體詳情信息,而Heroes組件需要顯示每一個Hero的詳細(xì)信息,這個時候,Heroes組件和heroDetail組件就有了主從關(guān)系,heroes組件需要將需要展示詳情的Hero對象傳給具有展示功能的HeroDetail組件

HeroDetailComponent 的選擇器是 'app-hero-detail'。 把 <app-hero-detail> 添加到 HeroesComponent 模板的底部,以便把英雄詳情的視圖顯示到那里,并把 HeroesComponent.selectedHero 綁定到該元素的 hero 屬性, HeroesComponent模版即:

<h2>My Heroes</h2>
<ul class="heroes">
 <li *ngFor="let hero of heroes" (click)="onSelect(hero)" [class.selected]="hero === selectedHero">
  <span class="badge">{{hero.id}}</span> {{hero.name}}
 </li>
</ul>
<app-hero-detail [hero]="selectedHero"></app-hero-detail>

保存瀏覽器刷新,界面和之前的不會有變化,但是會有一下優(yōu)點:

  • 通過縮減 HeroesComponent 的職責(zé)簡化了該組件。
  • 把 HeroDetailComponent 改進(jìn)成一個功能豐富的英雄編輯器,而不用改動父組件 HeroesComponent。
  • 改進(jìn) HeroesComponent,而不用改動英雄詳情視圖。
  • 將來可以在其它組件的模板中重復(fù)使用 HeroDetailComponent。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 理解AngularJs篇:30分鐘快速掌握AngularJs

    理解AngularJs篇:30分鐘快速掌握AngularJs

    這篇文章主要介紹了理解AngularJs篇:30分鐘快速掌握AngularJs,詳細(xì)介紹了AngularJs所涉及的知識點,有興趣的可以了解一下。
    2016-12-12
  • Angular 2 利用Router事件和Title實現(xiàn)動態(tài)頁面標(biāo)題的方法

    Angular 2 利用Router事件和Title實現(xiàn)動態(tài)頁面標(biāo)題的方法

    本篇文章主要介紹了Angular 2 利用Router事件和Title實現(xiàn)動態(tài)頁面標(biāo)題的方法,具有一定的參考價值,有興趣的可以了解一下
    2017-08-08
  • AngularJS入門教程之Hello World!

    AngularJS入門教程之Hello World!

    這篇文章主要介紹了AngularJS入門教程之Hello World!,本文用經(jīng)典的應(yīng)用程序“Hello World!”來講解AngularJS,要的朋友可以參考下
    2014-12-12
  • AngularJS基礎(chǔ) ng-copy 指令實例代碼

    AngularJS基礎(chǔ) ng-copy 指令實例代碼

    本文主要介紹AngularJS ng-copy 指令,這里幫大家整理了ng-copy指令的基礎(chǔ)資料,并附有示例代碼和效果圖,有需要的朋友參考下
    2016-08-08
  • angular4應(yīng)用中輸入的最小值和最大值的方法

    angular4應(yīng)用中輸入的最小值和最大值的方法

    這篇文章主要介紹了angular4應(yīng)用中輸入的最小值和最大值的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • 利用Angularjs和bootstrap實現(xiàn)購物車功能

    利用Angularjs和bootstrap實現(xiàn)購物車功能

    在學(xué)習(xí)了如何簡單開始一個Angular程序之后,跟著網(wǎng)上的教程我也來實現(xiàn)一個購物車功能,為了減少頁面樣式設(shè)計我使用了bootstrap來偷懶,現(xiàn)在分享給大家,有需要的可以參考借鑒。
    2016-08-08
  • Angular路由ui-router配置詳解

    Angular路由ui-router配置詳解

    這篇文章主要介紹了Angular路由ui-router配置詳解,非常不錯,具有一定得參考借鑒價值,需要的朋友參考下吧
    2018-08-08
  • Angular 常用指令實例總結(jié)整理

    Angular 常用指令實例總結(jié)整理

    這篇文章主要介紹了Angular 常用指令實例總結(jié)整理的相關(guān)資料,本文整理了常用指令,大家可以參考使用,需要的朋友可以參考下
    2016-12-12
  • Angular 路由route實例代碼

    Angular 路由route實例代碼

    下面小編就為大家?guī)硪黄狝ngular 路由route實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • RequireJS 依賴關(guān)系的實例(推薦)

    RequireJS 依賴關(guān)系的實例(推薦)

    下面小編就為大家?guī)硪黄猂equireJS 依賴關(guān)系的實例(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01

最新評論