Angular的:host、:host-context、::ng-deep選擇器
這篇文章帶大家深入了解一下angular中的幾個特殊選擇器:host、:host-context、::ng-deep,希望對大家有幫助!
一、 :host
#:host 表示選擇目前的元件。 【相關教學推薦:《angular教學》】
#1.1 選擇宿主元素
##使用:host 偽類選擇器,用來選擇元件
宿主元素中的元素(相對於元件模板內部的元素),沒有子元素就相當於選擇整個
宿主元素。
<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
標籤<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>:host h1 {
color:red;
}</pre><div class="contentsignin">登入後複製</div></div>
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>
元素中。 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>:host-context(.theme-light) h2 {
background-color: #eef;
}</pre><div class="contentsignin">登入後複製</div></div>
3.3 可以在:host-context後面新增選擇器以選擇子元素例如:
:host-context h1 定位元件視圖內的h1
標籤<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>:host-context h1{
color: hotpink;
}</pre><div class="contentsignin">登入後複製</div></div>
#3.4 可用來某個樣式內部條件判斷##h1{
color: hotpink;
:host-context(.active) &{
color: yellow;
}
}
以上是Angular的:host、:host-context、::ng-deep選擇器的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

這篇文章帶大家繼續angular的學習,簡單了解一下Angular中的獨立組件(Standalone Component),希望對大家有幫助!

Angular.js是一種可自由存取的JavaScript平台,用於建立動態應用程式。它允許您透過擴展HTML的語法作為模板語言,以快速、清晰地表示應用程式的各個方面。 Angular.js提供了一系列工具,可協助您編寫、更新和測試程式碼。此外,它還提供了許多功能,如路由和表單管理。本指南將討論在Ubuntu24上安裝Angular的方法。首先,您需要安裝Node.js。 Node.js是一個基於ChromeV8引擎的JavaScript運行環境,可讓您在伺服器端執行JavaScript程式碼。要在Ub

這篇文章跟大家分享一個Angular實戰,了解一下angualr 結合 ng-zorro 如何快速開發一個後台系統,希望對大家有幫助!

angular中怎麼使用monaco-editor?以下這篇文章記錄下最近的一次業務中用到的 monaco-editor 在 angular 中的使用,希望對大家有幫助!

隨著網路的快速發展,前端開發技術也不斷改進與迭代。 PHP和Angular是兩種廣泛應用於前端開發的技術。 PHP是一種伺服器端腳本語言,可以處理表單、產生動態頁面和管理存取權限等任務。而Angular是一種JavaScript的框架,可以用來開發單一頁面應用程式和建構元件化的網頁應用程式。本篇文章將介紹如何使用PHP和Angular進行前端開發,以及如何將它們

這篇文章帶大家了解Angular中的獨立元件,看看怎麼在Angular中建立一個獨立元件,怎麼在獨立元件中導入已有的模組,希望對大家有幫助!
