angular2 控制視圖的封裝模式

angular2 控制視圖的封裝模式

爲什麼我想要分享控制視圖的封裝模式呢?主要是我們angular的項目大多數都會去引入一個UI組件,但往往因爲需求和關係我們會去修改UI組件的樣式。這時,因爲有些人不是很瞭解View encapsulation裏面的屬性,往往會直接在全局的style.js裏面添加全局樣式,等項目越來越大,就會出現一些不知名的bug和維護起來變得困難。如果你運用好視圖的封裝模式,會幫你解決好很多的問題。
一般來說組件的 CSS 樣式被封裝進了自己的視圖中,而不會影響到應用程序的其它部分。通過在組件的元數據上設置視圖封裝模式,你可以分別控制每個組件的封裝模式。Angular2有三種樣式封裝模式:

  1. ViewEncapsulation.Native - 使用原生的Shadow Dom。
  2. ViewEncapsulation.Emulated - angular2的默認值,通過預處理(並改名)CSS 代碼來模擬 Shadow DOM 的行爲,在標籤上增加標識,來固定樣式的作用域,以達到把 CSS 樣式侷限在組件視圖中的目的。
  3. ViewEncapsulation.None - 沒有Shadow Dom,樣式沒有封裝, Angular 會把 CSS 添加到全局樣式中。而不會應用上前面討論過的那些作用域規則、隔離和保護等。 從本質上來說,這跟把組件的樣式直接放進 HTML 是一樣的。

在 ViewEncapsulation.Emulated下 的 Angular 應用的 DOM 樹中,每個 DOM 元素都被加上了一些額外的屬性。
<hero-details _nghost-pmm-5>
  <h2 _ngcontent-pmm-5>Mister Fantastic</h2>
  <hero-team _ngcontent-pmm-5 _nghost-pmm-6>
    <h3 _ngcontent-pmm-6>Team</h3>
  </hero-team>
</hero-detail>
生成出的屬性分爲兩種:
1、一個元素在原生封裝方式下可能是 Shadow DOM 的宿主,在這裏被自動添加上一個 _nghost 屬性。 這是組件宿主元素的典型情況。
2、組件視圖中的每一個元素,都有一個 _ngcontent 屬性,它會標記出該元素是哪個宿主的模擬 Shadow DOM。

用法如下:

import { Component, OnInit, ViewEncapsulation } from '@angular/core';
@Component({
    selector: 'app-factor_analysi',
    templateUrl: './factor_analysis.component.html',
    styleUrls: ['./factor_analysis.component.scss'],
    providers: [factor_analysis_api],
    encapsulation: ViewEncapsulation.None
})

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章