真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Angular模板中ng-template和ng-container指令的用法

這篇文章主要講解了“Angular模板中ng-template和ng-container指令的用法”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Angular模板中ng-template和ng-container指令的用法”吧!

我們提供的服務有:網(wǎng)站設計、成都網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、山南ssl等。為成百上千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術(shù)的山南網(wǎng)站制作公司

ng-template指令簡介

ng-template是一個 Angular 結(jié)構(gòu)型指令,用來渲染 HTML。 它永遠不會直接顯示出來。 事實上,在渲染視圖之前,Angular 會把 ng-template 及其內(nèi)容替換為一個注釋。

如果沒有使用結(jié)構(gòu)型指令,而僅僅把一些別的元素包裝進 ng-template 中,那些元素就是不可見的。

像*ngFor、 *ngIf這些指令Angular內(nèi)部會把這些屬性翻譯成一個 元素 并用它來包裹宿主元素。

ng-container指令簡介

為了避免創(chuàng)建額外的div,我們可以改用ng-container,它是一個分組元素,但它不會污染樣式或元素布局,因為 Angular 壓根不會把它放進 DOM 中。ng-container 是一個由 Angular 解析器負責識別處理的語法元素。 它不是一個指令、組件、類或接口,更像是 JavaScript 中 if 塊中的花括號。

ng-container用法

用法一(最基礎的用法)

我們在一個列表循環(huán)里有寫時候有一些判斷要完成,我們知道angular的結(jié)構(gòu)指令是不允許兩個同時存在的,這個時候如果我們又不想增加多余的div就可以用ng-container

                 {{item.context}}     

用法二(結(jié)合ngSwitch一起使用)


    標題
    內(nèi)容
    其他

當然ngSwitch也可以直接寫在html標簽上。

用法三(結(jié)合ng-template使用)

可以跟template配合使用,將重復的模塊內(nèi)容抽取出來,也可傳參給要顯示的模板。 比如下面的這個例子,甲方有甲方姓名和介紹,乙方也同樣有這些介紹,我們就可以把共同介紹整合出來。

         
        甲方:
                     甲方姓名                                                
    
         
        乙方:
                     乙方姓名                      
    
                  

合同介紹......

    

ngTemplateOutlet是定義模板引用和模板的上下文(即ng-template)對象的字符串,這樣如果有多個模板引用可以用這種方式 ngTemplateOutletContext是附加到的上下文(即ng-template)對象EmbeddedViewRef。這應該是一個對象,該對象的鍵可用于本地模板let 聲明的綁定。$implicit在上下文(即ng-template)對象中使用鍵會將其值設置為默認值。 ngTemplateOutlet也可用于外部傳進來的模板

child.component.html

child.component.ts

@Input() tplRef: TemplateRef

ng-template用法

用法一

結(jié)合*ngIf使用,這樣可以不用加兩次不同判斷條件,可以在html里直接使用if else語句

{{text}}

    暫無數(shù)據(jù)

用法二

頁面里使用antd的modalService創(chuàng)建對話框時,可以模板寫在html里面,通過引用加載過來放到modal的nzContent里(說的有點亂了,看代碼吧)

xxxxxxx
export class AppComponent implements OnInit {
    // 引入模板
     @ViewChild('content') contentTpl: TemplateRef;
    ngOnInit() {
        this.modalService.create({
            nzTitle: '標題',
            nzContent: this.contentTpl
        })
    }
}

用法三

以模板的形式,作為一個輸入變量傳給組件,這樣我們就可以在用這個組件時寫成自己想要的內(nèi)容 比如我們寫個共用的暫無數(shù)據(jù)的組件,一般只用傳text文字就可以有些特殊的時候我們可能需要一些新增按鈕。

empty.component.html

         
                                       {{text || ''}}     

empty.component.ts

export class EmptyComponent {
    @Input() text: TemplateRef
  isTemplate(text: any) {
      return text instanceof TemplateRef;
  }
}

總結(jié),都是一些最基礎的用法,現(xiàn)在所了解的就這些用法,如果有知道更多的歡迎大家補充。

感謝各位的閱讀,以上就是“Angular模板中ng-template和ng-container指令的用法”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對Angular模板中ng-template和ng-container指令的用法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!


本文標題:Angular模板中ng-template和ng-container指令的用法
網(wǎng)站路徑:http://weahome.cn/article/ieoeei.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部