一文了解angular中的3种内容投影(单插槽、多插槽、有条件)

本篇文章带大家了解下angular中的内容投影,介绍一下单插槽内容投影、多插槽内容投影、有条件的内容投影,希望对大家有所帮助!

一文了解angular中的3种内容投影(单插槽、多插槽、有条件)

【相关教程推荐:《angular教程》】

单插槽内容投影

单插槽内容投影是指创建一个组件,你可以在其中投影一个组件。

zippy-basic.component.ts

import { Component } from '@angular/core';@Component({  selector: 'app-zippy-basic',  template: `  

单插槽内容投影

  `})export class ZippyBasicComponent {}

登录后复制

有了 ng-content 元素,该组件的用户现在可以将自己的消息投影到该组件中。例如:

app.component.html

  

单插槽内容投影:投影数据

登录后复制

效果如下:
在这里插入图片描述

ng-content 元素是一个占位符,它不会创建真正的 DOM 元素。ng-content 的那些自定义属性将被忽略。

多插槽内容投影

组件模板含有多个ng-content标签。为了区分投影的内容可以投影到对应ng-content标签,需要使用ng-content标签上的select属性作为识别。select属性支持标签名、属性、CSS 类和 :not 伪类的任意组合。不添加select属性的ng-content标签将作为默认插槽。所有为匹配的投影内容都会投影在该ng-content的位置。

zippy-multislot.component.ts

import { Component } from '@angular/core';@Component({  selector: 'app-zippy-multislot',  template: `  

多插槽内容投影

    `})export class ZippyMultislotComponent {}

登录后复制

app.component.html

  

    带question属性的p元素  

  

不带question属性的p元素-->匹配到不带select属性的ng-content

  

不带question属性的p元素-->匹配到不带select属性的ng-content

登录后复制

效果如下:
在这里插入图片描述

在前面的示例中,只有第二个 ng-content 元素定义了select 属性。结果,第一个 ng-content 元素就会接收投影到组件中的任何其他内容。

有条件的内容投影

推荐使用ng-container标签,因为该标签不需要渲染真实的 DOM 元素。

登录后复制

参数 类型 说明

templateRefExpTemplateRef | null一个字符串,用于定义模板引用以及模板的上下文对象contextExpObject | null是一个对象,该对象的键名将可以在局部模板中使用 let 声明中进行绑定。在上下文对象中使用 $implicit 为键名时,将把它作为默认值。

ng-template 标签的#ID会匹配templateRefExp,将ng-template标签的内容嵌入到指定的ngTemplateOutlet中。

例一:

头部

内容:

底部

hi!

hello my dear friend!

登录后复制

效果:

在这里插入图片描述

ViewChild和ContentChild

ContentChild:与内容子节点有关,操作投影进来的内容;ViewChild:与视图子节点有关,操作自身的视图内容;

ContentChild

在上一部分,我们通过内容投影,让自定义的组件标签能够嵌入html标签或自定义组件标签,那么它如何操作投影进来的内容呢?

首先创建两个组件

/**** part-b.component.ts ****/import { Component, OnInit,Output} from '@angular/core';@Component({selector: 'app-content-part-b',templateUrl: './part-b.component.html',styleUrls: ['./part-b.component.scss']})export class PartBComponent implements OnInit {constructor() { }ngOnInit() { }public func():void{console.log("PartB");} }

登录后复制

/**** part-a.component.ts ****/import { Component, OnInit, ContentChild } from '@angular/core';// 1、引入 part-b 组件import { PartBComponent } from '../part-b/part-b.component';@Component({selector: 'app-content-part-a',templateUrl: './part-a.component.html',styleUrls: ['./part-a.component.scss']})export class PartAComponent implements OnInit {// 2、获取投影@ContentChild(PartBComponent) PartB:PartBComponentconstructor() { }ngOnInit() {}ngAfterContentInit(): void {// 3、调用 part-b 组件的 func() 方法this.PartB.func();}public func() {console.log('PartA')}}

登录后复制

将part-b组件的内容投影到part-a组件中

 
Content

PartA--start

PartA--end

登录后复制

在组件的生命周期里面,有一个钩子ngAfterContentInit()是与投影内容初始化有关,所以我们有关投影的内容操作尽量放在它初始化完成之后进行

ViewChild

上一部分的ContentChild操作的时投影进来的内容,而ViewChild操作的是自身的视图内容
给上一部分的content.component.html修改如下:

 
Content

PartA--start

PartA--end

登录后复制

/**** content.component.ts ****/import { Component, OnInit, ViewChild } from '@angular/core';@Component({selector: 'app-content',templateUrl: './content.component.html',styleUrls: ['./content.component.scss']})export class ContentComponent implements OnInit {// 2、获取视图 partA@ViewChild('partA') partA: any;constructor() { }ngOnInit() {}ngAfterViewInit(): void {// 3、调用 part-a 组件的 func() 方法this.partA.func();}}

登录后复制

ngAfterContentInit()对应的是ngAfterViewInit()(视图节点初始化是在投影内容初始化之后)

ContentChild和ViewChild还存在复数的形式,即ContentChildren和ViewChildren,它们取到的是节点的一个集合,其他的没有什么区别

写法如下:

import { Component, OnInit, ContentChild,ContentChildren ,QueryList } from '@angular/core';import { PartBComponent } from '../part-b/part-b.component';@Component({selector: 'app-content-part-a',templateUrl: './part-a.component.html',styleUrls: ['./part-a.component.scss']})export class PartAComponent implements OnInit {@ContentChildren(PartBComponent) PartBs: QueryList;constructor() { }ngOnInit() {}}

登录后复制

更多编程相关知识,请访问:编程入门!!

以上就是一文了解angular中的3种内容投影(单插槽、多插槽、有条件)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2707218.html

(0)
上一篇 2025年3月7日 20:10:24
下一篇 2025年3月7日 20:10:33

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论