Angular的:host、:host-context、::ng-deep選擇器

2022-05-31 14:02:40
本篇文章帶大家深入瞭解一下中的幾個特殊選擇器:host、:host-context、::ng-deep,希望對大家有所幫助!

一、 :host

:host 表示選擇當前的元件。【相關教學推薦:《》】

1.1 選擇宿主元素

使用 :host 偽類選擇器,用來選擇元件宿主元素中的元素(相對於元件模板內部的元素),沒有子元素就相當於選擇整個宿主元素

如有下面html:

<app-detail></app-detail>

元件 app-detail 的樣式(整個app-detail 的樣式)如下 :

:host {
    display: inline-block;
    background: red;
}

瀏覽器 Elements 選擇 app-detail 元素, Style 如下:

[_nghost-wtd-c445] {
    display: inline-block;
    background-color: red;
}

可以看得出來,:host 直接作用於宿主元素本身

1.2 選擇宿主元素的子元素

可以在 :host 後面新增選擇器以選擇子元素。例如::host h1 定位元件檢視內的 h1 標籤

:host h1 {
	color:red;
}

1.3 有條件的選擇宿主元素

把宿主作為目標,同時帶有 active 的 class 類的時候才會生效

:host(.active){
	border-width: 3px;
}

像這樣:

<app-detail class="active"></app-detail>

二、 ::ng-deep

::ng-deep 可以忽略中間 className 的巢狀層級關係。直接找到你要修改的 className。

在使用一些第三方的元件的時候,要修改元件的樣式,這種情況下使用.

2.1 從宿主元素到當前元素再到 DOM 中的所有子 h3 元素,包括當前元件中使用第三方元件的 h3 元素

:host ::ng-deep h3 {
  font-style: italic;
}

2.2 搜尋某型別下面的特定型別

.card-container ::ng-deep .ant-tabs-card .ant-tabs-content {
     height: 120px;
     margin-top: -16px;
}

三、 :host-context

如果需要滿足某條件才能應用樣式。它在當前元件宿主元素祖先節點中查詢 CSS 類,直到檔案的根節點為止。如果找到,才會應用後面的樣式到本元件內部元素。

3.1 選擇元件宿主元素中的元素

:host-context {
	color:red;
}

3.2 把宿主作為目標,同時帶有active的class類的時候才會生效

在下面的例子中,只有當某個祖先元素(宿主元素也可以)有 CSS 類 theme-light 時,才會把 background-color 樣式應用到本元件內部的所有 <h2> 元素中。

:host-context(.theme-light) h2 {
  background-color: #eef;
}

3.3 可以在:host-context後面新增選擇器以選擇子元素

例如::host-context h1 定位元件檢視內的 h1 標籤

:host-context h1{
    color: hotpink;
}

3.4 可用於某個樣式內部條件判斷

h1{
    color: hotpink;

    :host-context(.active) &{
        color: yellow;
    }
}

更多程式設計相關知識,請存取:!!

以上就是Angular的:host、:host-context、::ng-deep選擇器的詳細內容,更多請關注TW511.COM其它相關文章!