淺談Angular如何使用ng-content進行內容投影
在這篇文章中,我們將會探索如何使用 ng-content
進行內容投影,來建立靈活的可重複使用元件。
ng-content
ng-content
元素是用來插入外部或動態內容的佔位符。父元件將外部內容傳遞給子元件,當 Angular 解析範本時,就會在子元件範本中 ng-content
出現的地方插入外部內容。
我們可以使用內容投影來建立可重複使用的元件。這些組件有相似的邏輯和佈局,並且可以在許多地方使用。一般我們在封裝一些公共組件的時候常常會用到。 【相關教學推薦:《angular教學》】
不使用內容投影
為了理解為什麼要使用ng-content
進行內容投影,首先讓我們來建立一個很常見的button 元件。
btn.component.ts
import { Component } from '@angular/core'; @Component({ selector: 'app-btn', templateUrl: './btn.component.html', styleUrls: ['./btn.component.scss'], }) export class BtnComponent { constructor() {} onClick($event: any) { console.log($event); } }
btn.component.html
<button (click)=onClick($event)> Click Me </button>
在這個元件中,button 的文字總是Click Me
,如果我們想傳遞不同的文本進來呢?或許你會想到最常使用的 @Input
裝飾器,但如果我們不只是想傳文字進來,而是傳一段 html 進來呢?這時候就需要用到這篇文章的主角:ng-content
。
單一插槽內容投影
內容投影的最基本形式是單一插槽內容投影。單插槽內容投影是指創建一個元件,我們可以在其中投影一個元件。
要建立使用單一插槽內容投影的元件,我們只需要對上面的元件做一些簡單的修改:把Click Me
替換為<ng-content> </ng-content>
。
btn.component.html
<button (click)=onClick($event)> <ng-content></ng-content> </button>
在使用btn 元件的地方:
<app-btn>Cancel</app-btn> <app-btn><b>Submit</b></app-btn>
在<app-btn></app-btn>
中的內容會傳遞給btn 元件,並且顯示在ng-contnet
中。
多插槽內容投影
上面的 btn 元件非常簡單,但實際上ng-content
要比這個更強大。一個元件可以有多個插槽,每個插槽可以指定一個 CSS 選擇器,該選擇器會決定要將哪些內容放入該插槽。此模式稱為多插槽內容投影。使用此模式,我們必須指定希望投影內容出現在的位置。可以透過使用 ng-content
的 select
屬性來完成此任務。
要建立使用多插槽內容投影的元件,需要執行以下操作:
#建立一個元件。
在元件範本中,加入
ng-content
元素,讓你希望投影的內容出現在其中。將
select
屬性加入到ng-content
元素。 Angular 使用的選擇器支援標籤名、屬性、CSS 類別和:not
偽類的任意組合。
下面我們來建立一個複雜一些的 card 元件。
card.component.html
<div class="card"> <div class="header"> <ng-content select="header"></ng-content> </div> <div class="content"> <ng-content select="content"></ng-content> </div> <div class="footer"> <ng-content select="footer"></ng-content> </div> </div>
在使用card 元件的地方:
app.component.html
<app-card> <header> <h1>Angular</h1> </header> <content>One framework. Mobile & desktop.</content> <footer><b>Super-powered by Google </b></footer> </app-card> <app-card> <header> <h1 style="color:red;">React</h1> </header> <content>A JavaScript library for building user interfaces</content> <footer><b>Facebook Open Source </b></footer> </app-card>
如果在app- card
中有不屬於header, content, footer 以外的內容呢?例如依照下面的寫法使用app-card
元件:
app.component.html
<app-card> <header> <h1>Angular</h1> </header> <div>Not match any selector</div> <content>One framework. Mobile & desktop.</content> <footer><b>Super-powered by Google </b></footer> <div>This text will not not be shown</div> </app-card>
會發現兩個div
都沒有渲染在頁面中,為了解決這個問題,我們可以在元件中加入一個沒有任何selector
的ng-content
標籤。所有沒辦法匹配到任何其他插槽的內容都會被渲染在這個裡面。
card.component.html
<div class="card"> <div class="header"> <ng-content select="header"></ng-content> </div> <div class="content"> <ng-content select="content"></ng-content> </div> <div class="footer"> <ng-content select="footer"></ng-content> </div> <ng-content></ng-content> </div>
ngProjectAs
在某些情況下,我們需要使用ng-container
把一些內容包裹起來傳遞到組件中。大多數情況是因為我們需要使用結構型指令像 ngIf
或 ngSwitch
等。例如只有在某些情況下才會向 card 元件傳遞 header。
在下面的範例中,我們將 header 包裹在了 ng-container
中。
<app-card> <ng-container> <header> <h1>Angular</h1> </header> </ng-container> <content>One framework. Mobile & desktop.</content> <footer><b>Super-powered by Google </b></footer> </app-card>
由於ng-container
的存在,header 部分並沒有被渲染到我們想要渲染的插槽中,而是渲染到了沒有提供任何selector 的ng- content
中。
在這種情況下,我們可以使用 ngProjectAs
屬性。
在上面的 ng-container
加上這個屬性,就可以按照我們的期望來渲染了。
<app-card> <ng-container ngProjectAs='header'> ... </app-card>
更多程式相關知識,請造訪:程式設計教學! !
以上是淺談Angular如何使用ng-content進行內容投影的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

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

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

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

Dreamweaver CS6
視覺化網頁開發工具

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

這篇文章繼續Angular的學習,帶大家了解Angular中的元數據和裝飾器,簡單了解一下他們的用法,希望對大家有幫助!

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

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

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

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

身份驗證是任何網路應用程式中最重要的部分之一。本教程討論基於令牌的身份驗證系統以及它們與傳統登入系統的差異。在本教程結束時,您將看到一個用Angular和Node.js編寫的完整工作演示。傳統身份驗證系統在繼續基於令牌的身份驗證系統之前,讓我們先來看看傳統的身份驗證系統。使用者在登入表單中提供使用者名稱和密碼,然後點擊登入。發出請求後,透過查詢資料庫在後端驗證使用者。如果請求有效,則使用從資料庫中獲取的使用者資訊建立會話,然後在回應頭中傳回會話訊息,以便將會話ID儲存在瀏覽器中。提供用於存取應用程式中受
