91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-24 04:44:24 來源:腳本之家 閱讀:166 作者:Twait 欄目:web開發

為什么我想要分享控制視圖的封裝模式呢?主要是我們angular的項目大多數都會去引入一個UI組件,但往往因為需求和關系我們會去修改UI組件的樣式。這時,因為有些人不是很了解View encapsulation里面的屬性,往往會直接在全局的style.js里面添加全局樣式,等項目越來越大,就會出現一些不知名的bug和維護起來變得困難。如果你運用好視圖的封裝模式,會幫你解決好很多的問題。

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

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

在 ViewEncapsulation.Emulated下 的 Angular 應用的 DOM 樹中,每個 DOM 元素都被加上了一些額外的屬性。

<hero-details _nghost-pmm-5>
 <h3 _ngcontent-pmm-5>Mister Fantastic</h3>
 <hero-team _ngcontent-pmm-5 _nghost-pmm-6>
  <h4 _ngcontent-pmm-6>Team</h4>
 </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
})

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大埔区| 许昌市| 吉林市| 阳江市| 临潭县| 团风县| 涟源市| 宾阳县| 秭归县| 永福县| 永康市| 台东市| 滁州市| 阜新| 岢岚县| 清远市| 陈巴尔虎旗| 丹棱县| 义乌市| 湘阴县| 大同县| 集贤县| 林州市| 江门市| 永顺县| 鄂州市| 平度市| 金坛市| 清河县| 寻甸| 阿克| 钟祥市| 河间市| 中方县| 凌海市| 巩留县| 郯城县| 苗栗市| 五大连池市| 永年县| 栾城县|