使用ng-content進(jìn)行組件內(nèi)容投射

大綱

1、認(rèn)識(shí)內(nèi)容投射
2啄枕、一個(gè)簡(jiǎn)單組件
3婚陪、簡(jiǎn)單投射
4、針對(duì)性投射
5频祝、ngProjectAs
6泌参、代碼資源

認(rèn)識(shí)內(nèi)容投射

在angular中脆淹,組件屬于特殊的指令,它的特殊之處在于它有自己的模板(html)和樣式(css)沽一。因此使用組件可以使我們的代碼具有強(qiáng)解耦盖溺、可復(fù)用、易擴(kuò)展等特性铣缠。

一個(gè)簡(jiǎn)單組件
/*
  demo.component.ts
*/
import { Component, OnInit } from ‘@angular/core‘;
@Component({
    selector: 'demo-component',
    templateUrl: './demo.component.html',
    styleUrls: ['./demo.component.scss']
})
export class DemoComponent implements OnInit {
    constructor() {
    }
    ngOnInit() {
    }
}
<!--
    demo.component.html: 
-->
<div class="demo">
    <h2>
        demo-component - 我是一個(gè)簡(jiǎn)單的組件
    </h2>
</div>
/*
    demo.component.scss:
*/
.demo {
    padding: 10px;
    border: 2px solid red;

    h2 {
        margin: 0;
        color: #262626;
    }
}
<!--
    此時(shí)我們引用該組件烘嘱,就會(huì)呈現(xiàn)該組件解析之后的內(nèi)容:
-->
<demo-component></demo-component>
簡(jiǎn)單組件
需求

假設(shè)現(xiàn)在有這樣的需求,這個(gè)組件能夠接受外部投射進(jìn)來(lái)的內(nèi)容攘残,也就是說(shuō)組件最終呈現(xiàn)的內(nèi)容不僅僅是本身定義的那些拙友,那該怎么做呢?這時(shí)就要請(qǐng)出本文的主角 ng-content歼郭。

簡(jiǎn)單投射
<!--
    demo.component.html:
-->
<div class="demo">
    <h2>
        demo-component - 可嵌入外部?jī)?nèi)容的組件
    </h2>
    <div class="content">
        <ng-content></ng-content>
    </div>
</div>
/*
    demo.component.scss:
*/
.demo {
    padding: 10px;
    border: 2px solid red;

    h2 {
        margin: 0;
        color: #262626;
    }

    .content {
        padding: 10px;
        margin-top: 10px;
        line-height: 20px;
        color: #FFFFFF;
        background-color: #de7d28;
    }
}
<!--
    為了效果展示特意將 所在的容器背景色定義為橙色。

    這時(shí)我們?cè)谝迷摻M件時(shí)可以從外部投射內(nèi)容辐棒,外部?jī)?nèi)容將在橙色區(qū)域顯示:
-->
<demo-component>
    我是外部嵌入的內(nèi)容
</demo-component>
簡(jiǎn)單投射
針對(duì)性投射

如果同時(shí)存在幾個(gè)外部?jī)?nèi)容病曾,那外部?jī)?nèi)容將如何進(jìn)行投射呢?
如果同時(shí)存在簡(jiǎn)單的外部?jī)?nèi)容漾根,那么外部?jī)?nèi)容將投射在組件模板最后的那個(gè)ng-content中泰涂。

<!--
    demo.component.html:
-->
<div class="demo">
    <h2>
        demo-component - 可嵌入外部?jī)?nèi)容的組件
    </h2>
    <div class="content">
        <ng-content></ng-content>
    </div>
    <div class="content blue">
        <ng-content select="header"></ng-content>
    </div>
    <div class="content red">
        <ng-content select=".demo2"></ng-content>
    </div>
    <div class="content green">
        <ng-content select="[name=demo3]"></ng-content>
    </div>
</div>
/*
    demo.component.scss:
*/
.demo {
    padding: 10px;
    border: 2px solid red;

    h2 {
        margin: 0;
        color: #262626;
    }

    .content {
        padding: 10px;
        margin-top: 10px;
        line-height: 20px;
        color: #FFFFFF;
        background-color: #de7d28;

        &.blue {
            background-color: blue;
        }

        &.red {
            background-color: red;
        }

        &.green {
            background-color: green;
        }
    }
}
<!--
    從上面代碼可以看到,藍(lán)色區(qū)域?qū)⒔邮?標(biāo)簽 header 那部分內(nèi)容辐怕,
    紅色區(qū)域?qū)⒔邮?class為"demo2"的div 的那部分內(nèi)容逼蒙,
    綠色區(qū)域?qū)⒔邮?屬性name為"demo3"的div 的那部分內(nèi)容,
    橙色區(qū)域?qū)⒔邮掌溆嗟耐獠績(jī)?nèi)容(開(kāi)始寄疏,我是外部嵌入的內(nèi)容是牢,結(jié)束)。

    引用該組件:此時(shí)陕截,我們將看到外部?jī)?nèi)容投射到了指定的 中驳棱。
-->

<demo-component>
    開(kāi)始,我是外部嵌入的內(nèi)容农曲,
    <header>
        我是外部嵌入的內(nèi)容社搅,我在header中
    </header>
    <div class="demo2">
        我是外部嵌入的內(nèi)容,我所在div的class為"demo2"
    </div>
    <div name="demo3">
        我是外部嵌入的內(nèi)容demo乳规,我所在div的屬性name為"demo3"
    </div>
    結(jié)束
</demo-component>
針對(duì)性投射
ngProjectAs

現(xiàn)在我們知道通過(guò) ng-content 的 select 屬性可以指定外部?jī)?nèi)容投射到指定的元素中形葬。
而要能正確的根據(jù) select 屬性投射內(nèi)容,有個(gè)限制就是 - 不管是 標(biāo)簽 header暮的、class為"demo2"的div還是 屬性name為"demo3"的div笙以,這幾個(gè)標(biāo)簽都是作為 組件標(biāo)簽 的直接子節(jié)點(diǎn)。
通過(guò)設(shè)置 ngProjectAs 屬性青扔,讓 標(biāo)簽header 所在的 div 指向了 select="header"源织,此時(shí) 標(biāo)簽 header 那部分內(nèi)容有投射到藍(lán)色區(qū)域了翩伪。

<demo-component>
    開(kāi)始,我是外部嵌入的內(nèi)容谈息,
    <div ngProjectAs="header">
        <header>
            我是外部嵌入的內(nèi)容缘屹,我在header中
        </header>
    </div>
    <div class="demo2">
        我是外部嵌入的內(nèi)容,我所在div的class為"demo2"
    </div>
    <div name="demo3">
        我是外部嵌入的內(nèi)容demo侠仇,我所在div的屬性name為"demo3"
    </div>
    結(jié)束
</demo-component>
代碼資源

angular實(shí)例代碼中angular-ng-content中包含著使用ng-content進(jìn)行組件內(nèi)容投射轻姿,里面有本篇博客中所包含的所有實(shí)例,從一個(gè)簡(jiǎn)單組件到內(nèi)容投射都含有逻炊,如果有興趣的讀者可以從git上下載下來(lái)嘗試互亮。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市余素,隨后出現(xiàn)的幾起案子豹休,更是在濱河造成了極大的恐慌,老刑警劉巖桨吊,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件威根,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡视乐,警方通過(guò)查閱死者的電腦和手機(jī)洛搀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)佑淀,“玉大人留美,你說(shuō)我怎么就攤上這事∩烊校” “怎么了谎砾?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)奕枝。 經(jīng)常有香客問(wèn)我棺榔,道長(zhǎng),這世上最難降的妖魔是什么隘道? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任症歇,我火速辦了婚禮,結(jié)果婚禮上谭梗,老公的妹妹穿的比我還像新娘忘晤。我一直安慰自己,他們只是感情好激捏,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布设塔。 她就那樣靜靜地躺著,像睡著了一般远舅。 火紅的嫁衣襯著肌膚如雪闰蛔。 梳的紋絲不亂的頭發(fā)上痕钢,一...
    開(kāi)封第一講書(shū)人閱讀 49,741評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音序六,去河邊找鬼任连。 笑死,一個(gè)胖子當(dāng)著我的面吹牛例诀,可吹牛的內(nèi)容都是我干的随抠。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼繁涂,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼拱她!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起扔罪,我...
    開(kāi)封第一講書(shū)人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤秉沼,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后矿酵,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體氧猬,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年坏瘩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片漠魏。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡倔矾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出柱锹,到底是詐尸還是另有隱情哪自,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布禁熏,位于F島的核電站壤巷,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏瞧毙。R本人自食惡果不足惜胧华,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宙彪。 院中可真熱鬧矩动,春花似錦、人聲如沸释漆。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)男图。三九已至示姿,卻和暖如春甜橱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背栈戳。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工岂傲, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人荧琼。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓譬胎,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親命锄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子堰乔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348