詳解angular2 控制視圖的封裝模式
為什么我想要分享控制視圖的封裝模式呢?主要是我們angular的項目大多數(shù)都會去引入一個UI組件,但往往因為需求和關系我們會去修改UI組件的樣式。這時,因為有些人不是很了解View encapsulation里面的屬性,往往會直接在全局的style.js里面添加全局樣式,等項目越來越大,就會出現(xiàn)一些不知名的bug和維護起來變得困難。如果你運用好視圖的封裝模式,會幫你解決好很多的問題。
一般來說組件的 CSS 樣式被封裝進了自己的視圖中,而不會影響到應用程序的其它部分。通過在組件的元數(shù)據(jù)上設置視圖封裝模式,你可以分別控制每個組件的封裝模式。Angular2有三種樣式封裝模式:
- ViewEncapsulation.Native - 使用原生的Shadow Dom。
- ViewEncapsulation.Emulated - angular2的默認值,通過預處理(并改名)CSS 代碼來模擬 Shadow DOM 的行為,在標簽上增加標識,來固定樣式的作用域,以達到把 CSS 樣式局限在組件視圖中的目的。
- ViewEncapsulation.None - 沒有Shadow Dom,樣式沒有封裝, Angular 會把 CSS 添加到全局樣式中。而不會應用上前面討論過的那些作用域規(guī)則、隔離和保護等。 從本質上來說,這跟把組件的樣式直接放進 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 })
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
AngularJS學習筆記(三)數(shù)據(jù)雙向綁定的簡單實例
這篇文章主要介紹了AngularJS學習筆記(三)數(shù)據(jù)雙向綁定的簡單實例,詳解數(shù)據(jù)雙向綁定實例的相關資料,需要的朋友可以參考下。2016-11-11AngularJS基礎 ng-selected 指令簡單示例
本文主要介紹AngularJS ng-selected 指令,這里對ng-selected 指令的基礎資料做了詳細介紹,并附有示例代碼,有需要的小伙伴可以參考下2016-08-08Facade Service暴露commands簡化代碼邏輯提高可訪問性組合性
在 Angular 應用開發(fā)中,使用 Facade Service 暴露 commands(命令)以及訂閱這些 commands 是一個常見的設計模式,本文將詳細介紹在 Facade Service 中如何實現(xiàn)這一目標,并深入探討相關細節(jié),以及通過實際示例進行說明2023-10-10Angularjs自定義指令實現(xiàn)分頁插件(DEMO)
由于最近的一個項目使用的是angularjs1.0的版本,涉及到分頁查詢數(shù)據(jù)的功能,后來自己就用自定義指令實現(xiàn)了該功能,下面小編把實例demo分享到腳本之家平臺,需要的朋友參考下2017-09-09Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output詳解(下)
這篇文章主要給大家介紹了關于Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-07-07AngularJs Dependency Injection(DI,依賴注入)
本文主要介紹AngularJs Dependency Injection,這里整理了詳細資料及示例代碼有興趣的小伙伴可以參考下2016-09-09AngularJS深入探討scope,繼承結構,事件系統(tǒng)和生命周期
這篇文章主要介紹了AngularJS的scope,繼承結構,事件系統(tǒng)和生命周期,較為詳細的分析了scope的作用域、層次結構、繼承及生命周期相關概念與使用技巧,需要的朋友可以參考下2016-11-11