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

詳解angular2 控制視圖的封裝模式

 更新時(shí)間:2018年12月27日 11:32:33   作者:Twait  
這篇文章主要介紹了詳解angular2 控制視圖的封裝模式,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

為什么我想要分享控制視圖的封裝模式呢?主要是我們angular的項(xiàng)目大多數(shù)都會去引入一個UI組件,但往往因?yàn)樾枨蠛完P(guān)系我們會去修改UI組件的樣式。這時(shí),因?yàn)橛行┤瞬皇呛芰私釼iew encapsulation里面的屬性,往往會直接在全局的style.js里面添加全局樣式,等項(xiàng)目越來越大,就會出現(xiàn)一些不知名的bug和維護(hù)起來變得困難。如果你運(yùn)用好視圖的封裝模式,會幫你解決好很多的問題。

一般來說組件的 CSS 樣式被封裝進(jìn)了自己的視圖中,而不會影響到應(yīng)用程序的其它部分。通過在組件的元數(shù)據(jù)上設(shè)置視圖封裝模式,你可以分別控制每個組件的封裝模式。Angular2有三種樣式封裝模式:

  • ViewEncapsulation.Native - 使用原生的Shadow Dom。
  • ViewEncapsulation.Emulated - angular2的默認(rèn)值,通過預(yù)處理(并改名)CSS 代碼來模擬 Shadow DOM 的行為,在標(biāo)簽上增加標(biāo)識,來固定樣式的作用域,以達(dá)到把 CSS 樣式局限在組件視圖中的目的。
  • ViewEncapsulation.None - 沒有Shadow Dom,樣式?jīng)]有封裝, Angular 會把 CSS 添加到全局樣式中。而不會應(yīng)用上前面討論過的那些作用域規(guī)則、隔離和保護(hù)等。 從本質(zhì)上來說,這跟把組件的樣式直接放進(jìn) HTML 是一樣的。

在 ViewEncapsulation.Emulated下 的 Angular 應(yīng)用的 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 屬性,它會標(biāo)記出該元素是哪個宿主的模擬 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
})

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

相關(guān)文章

最新評論