本文摘自PHP中文网,作者青灯夜游,侵删。

在这篇文章中,我们将会探索如何使用 ng-content
进行内容投影,来创建灵活的可复用组件。
ng-content
ng-content
元素是一个用来插入外部或者动态内容的占位符。父组件将外部内容传递给子组件,当 Angular 解析模板时,就会在子组件模板中 ng-content
出现的地方插入外部内容。
我们可以使用内容投影来创建可重用的组件。这些组件有相似的逻辑和布局,并且可以在许多地方使用。一般我们在封装一些公共组件的时候经常会用到。【相关教程推荐:《angular教程》】
不使用内容投影
为了理解为什么要使用 ng-content
进行内容投影,首先让我们来创建一个很常见的 button 组件。
btn.component.ts
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
btn.component.html
1 2 3 |
|
在这个组件中,button 的文本始终是 Click Me
,如果我们想传递不同的文本进来呢?可能你会想到最常使用的 @Input
装饰器,但是如果我们不只是想传文本进来,而是传一段 html 进来呢?这个时候就需要用到这篇文章的主角:ng-content
。
单插槽内容投影
内容投影的最基本形式是单插槽内容投影。单插槽内容投影是指创建一个组件,我们可以在其中投影一个组件。
要创建使用单插槽内容投影的组件,我们只需要对上面的组件进行一些简单的修改:把 Click Me
替换为 <ng-content></ng-content>
。
btn.component.html
1 2 3 |
|
在使用 btn 组件的地方:
1 2 |
|
在 <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
1 2 3 4 5 6 7 8 9 10 11 |
|
在使用 card 组件的地方:
app.component.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
如果在 app-card
中有不属于 header, content, footer 之外的内容呢?比如按照下面的写法使用 app-card
组件:
相关阅读 >>
聊聊Angular项目中将 .css 文件修改为 .scss 文件的方法
更多相关阅读请进入《Angular》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者