返回顶部
首页 > 资讯 > 前端开发 > VUE >如何使用Angular组件实现内容投影
  • 378
分享到

如何使用Angular组件实现内容投影

2024-04-02 19:04:59 378人浏览 薄情痞子
摘要

这篇文章给大家介绍如何使用angular组件实现内容投影,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. 投影一块内容容器组件这样写<div>   编

这篇文章给大家介绍如何使用angular组件实现内容投影,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1. 投影一块内容

容器组件这样写

<div>
  编号1
  <ng-content></ng-content>
</div>

业务组件这样用

<app-page-container>
	未指定投影位置的内容会被投影到无select属性的区域
</app-page-container>
2. 投影多块内容/组件

容器组件这样写

  • 使用标签定投影位置

  • 使用class锁定投影位置

  • 用自定义组件名称锁定投影位置

  • 使用自定义属性锁定投影位置

<div>
  编号2
  <ng-content select="h4"></ng-content>
  <ng-content select=".my-class"></ng-content>
  <ng-content select="app-my-hello"></ng-content>
  <ng-content select="[content]"></ng-content>
</div>

业务组件这样用

<app-page-container>
  <h4>使用标签锁定投影位置</h4>
  <div class="my-class">使用class锁定投影位置</div>
  <app-my-hello>使用自定义组件名称锁定投影位置</app-my-hello>
  <div content>使用自定义属性锁定投影位置</div>
</app-page-container>

演示

如何使用Angular组件实现内容投影

3. 投影子元素

使用ng-container来包裹子元素,减少不必要的dom层,类似Vue中的template

容器组件这样写

<div>
  编号4
  <ng-content select="question"></ng-content>
</div>

业务组件这样写

<app-page-container>
  <ng-container ngProjectAs="question">
    <p>内容投影酷吗?</p>
    <p>内容投影酷吗?</p>
    <p>内容投影酷吗?</p>
    <p>内容投影酷吗?</p>
  </ng-container>
</app-page-container>
4. 有条件的内容投影

中文网的描述:

  • 如果你的组件需要_有条件地_渲染内容或多次渲染内容,则应配置该组件以接受一个 ng-template 元素,其中包含要有条件渲染的内容。

  • 在这种情况下,不建议使用 ng-content 元素,因为只要组件的使用者提供了内容,即使该组件从未定义 ng-content 元素或该 ng-content 元素位于 ngIf 语句的内部,该内容也总会被初始化。

  • 使用 ng-template 元素,你可以让组件根据你想要的任何条件显式渲染内容,并可以进行多次渲染。在显式渲染 ng-template 元素之前,Angular 不会初始化该元素的内容。

使用ng-container定义我们的投影区块

  • 使用ngTemplateOutlet指令来渲染ng-template元素。

  • 通过内置的动态指令*ngIf来控制是否渲染投影。

<div>
  编号3
  <ng-content select="[button]"></ng-content>
  <p *ngIf="expanded">
    <ng-container [ngTemplateOutlet]="content.templateRef"> </ng-container>
  </p>
</div>

在业务组件中我们使用ng-template来包裹我们的实际元素。

my-hello组件只在nGonInit()做日志输出来观察打印情况。

<app-page-container>
  <div button>
    <button appToggle>切换</button>
  </div>
  <ng-template appContent>
    <app-my-hello>有条件的内容投影~</app-my-hello>
  </ng-template>
</app-page-container>

现在你会发现页面并没有像前面那么顺利的正常渲染,因为我们的逻辑还没有串通,我们继续。创建一个指令,并在NgModule中注册,一定要注册才能用哦~

指令需要注册哦~

import { Directive, TemplateRef } from '@angular/core';

@Directive({
  selector: '[appContent]',
})
export class ContentDirective {
  constructor(public templateRef: TemplateRef<unknown>) {}
}

我们再定义一个指令来控制组件中显示/隐藏的标识

指令需要注册哦~

@Directive({
  selector: '[appToggle]',
})
export class ToggleDirective {
  @HostListener('click') toggle() {
    this.app.expanded = !this.app.expanded;
  }
  constructor(public app: PageContainerComponent) {}
}

在我们的容器组件中申明刚才定义的内容指令,页面目前不报错咯~

export class PageContainerComponent implements OnInit {

  expanded: boolean = false;

  @ContentChild(ContentDirective)
  content!: ContentDirective;

}

通过日志可以看到我们在切换容器组件的expanded标识时,只有开启状态my-hello组件才会初始化,下面的这个ngIf虽然在页面看不到渲染的内容,但组件实实在在被初始化过了。

<div *ngIf="false">
  <ng-content *ngIf="false" select="app-my-hello"></ng-content>
</div>
5. @ContentChild & @ContentChildren

使用这两个装饰器来对被投影的组件进行操作

使用注解在业务组件中定义被投影的组件

@ContentChild(HelloWorldComp)
helloComp: HelloWorldComp;

@ContentChildren(HelloWorldComp)
helloComps: QueryList<HelloWorldComp>;

ngAfterContentInit()钩子执行后对被投影组件进行操作

6. @ViewChild & @ViewChildren

使用这两个装饰器来对指接子组件进行操作

使用注解在业务组件中定义子组件

@ViewChild(HelloWorldComp)
helloComp: HelloWorldComp;
  
@ViewChildren(HelloWorldComp)
helloComps QueryList<HelloWorldComp>;

ngAfterViewInit()钩子执行后对直接子组件进行操作

关于如何使用Angular组件实现内容投影就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 如何使用Angular组件实现内容投影

本文链接: https://lsjlt.com/news/77409.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何使用Angular组件实现内容投影
    这篇文章给大家介绍如何使用Angular组件实现内容投影,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. 投影一块内容容器组件这样写<div>   编...
    99+
    2024-04-02
  • angular内容投影怎么实现
    这篇文章主要讲解了“angular内容投影怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“angular内容投影怎么实现”吧!单内容投影利用ng-content来实现<!--&n...
    99+
    2023-06-22
  • 使用Angular组件怎么实现投影
    本篇文章为大家展示了使用Angular组件怎么实现投影,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、子组件中使用<ng-content>指令来标记投影点<div cl...
    99+
    2023-06-15
  • Angular怎么使用ng-content进行内容投影
    小编给大家分享一下Angular怎么使用ng-content进行内容投影,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2024-04-02
  • Angular如何利用内容投射向组件输入ngForOf模板
    这篇文章主要介绍了Angular如何利用内容投射向组件输入ngForOf模板,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。现在,我们写一个组...
    99+
    2024-04-02
  • css如何实现投影
    这篇文章主要介绍了css如何实现投影,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。投影添加此属性可为透明图像带来更好的阴影效果。您可以使用给定的代码行执行此操作。.img-w...
    99+
    2023-06-27
  • Angular如何实现组件化管理
    这篇文章主要介绍Angular如何实现组件化管理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:在做sass产品页面的时候,往往每个页面的header和footer都是一样的...
    99+
    2024-04-02
  • angular倒计时组件如何使用
    这篇文章主要介绍“angular倒计时组件如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“angular倒计时组件如何使用”文章能帮助大家解决问题。组件cou...
    99+
    2024-04-02
  • 使用Java如何实现追加文件内容
    这篇文章将为大家详细讲解有关使用Java如何实现追加文件内容,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。整理文档,搜刮出一个Java追加文件内容的三种方法的代码,稍微整理精简一下做下分享。...
    99+
    2023-05-31
    java 文件追加 ava
  • 如何使用Angular+Angular-Ui实现分页
    这篇文章主要介绍如何使用Angular+Angular-Ui实现分页,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!先看效果:采用了Angular-UI中的分页组件,关于Angular...
    99+
    2024-04-02
  • 如何使用Angular CDK Portal创建动态内容
    这篇文章将为大家详细讲解有关如何使用Angular CDK Portal创建动态内容,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Angular 官方提供了一套组件开发套...
    99+
    2024-04-02
  • Angular中的独立组件如何使用
    这篇文章主要介绍“Angular中的独立组件如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Angular中的独立组件如何使用”文章能帮助大家解决问题。如何创...
    99+
    2024-04-02
  • 如何使用PHP实现微信小程序的投影功能?
    如何使用PHP实现微信小程序的投影功能?随着微信小程序的快速发展,越来越多的开发者开始关注其功能的拓展与扩展。其中,投影功能是一个受到用户欢迎的特性。通过投影功能,用户可以将小程序上的内容投射到更大的屏幕上,提供更好的视觉体验。本文将介绍如...
    99+
    2023-10-27
    PHP 微信小程序 投影功能
  • 如何使用Angular CDK实现一个Service弹出Toast组件功能
    这篇文章将为大家详细讲解有关如何使用Angular CDK实现一个Service弹出Toast组件功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.环境安装cdk不是angular的默认模块,需要手动...
    99+
    2023-06-20
  • angular组件继承如何实现第1/2页
    这篇文章主要介绍了angular组件继承如何实现第1/2页,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Angular 2.3 版本中引入了...
    99+
    2024-04-02
  • 如何实现一个angular版本的Message组件
    这篇文章主要介绍如何实现一个angular版本的Message组件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!学习一个框架或库的最好方法是看官方文档,并着手去写例子。最近在利用空闲...
    99+
    2024-04-02
  • 使用java如何实现向文件中追加内容
    使用java如何实现向文件中追加内容?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。java向文件中追加内容与读写文件内容源码实例代码向文件尾加入内容有多种方法,...
    99+
    2023-05-31
    java 追加内容 ava
  • win10投影仪扩展模式如何使用
    这篇“win10投影仪扩展模式如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“win10投影仪扩展模式如何使用”文章吧...
    99+
    2023-06-30
  • css如何实现内阴影
    这篇文章将为大家详细讲解有关css如何实现内阴影,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   CSS代码:      box-s...
    99+
    2024-04-02
  • 如何使用CSS3配合IE滤镜实现渐变和投影的效果
    本篇内容介绍了“如何使用CSS3配合IE滤镜实现渐变和投影的效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作