angular内容投影怎么实现
发表于:2025-01-16 作者:千家信息网编辑
千家信息网最后更新 2025年01月16日,这篇文章主要讲解了"angular内容投影怎么实现",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"angular内容投影怎么实现"吧!单内容投影利用ng
千家信息网最后更新 2025年01月16日angular内容投影怎么实现
这篇文章主要讲解了"angular内容投影怎么实现",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"angular内容投影怎么实现"吧!
单内容投影
利用ng-content来实现
标题
this is content
多内容投影
利用ng-content
来实现
Herder Title
Body Title
Default Title
Footer Title
this is default01this is headerthis is default02this is bodythis is default03this is default04
有条件的内容投影-ng-template
, ng-container
, directive
等来配合实现
单个条件的内容投影
eg: 假设现在有一个人员列表,当某个人的money大于200的时候,额外添加组件中模板定义的内容
定义一个 appChildRef 指令来配合 ng-template 获取模板
import { Directive, TemplateRef } from '@angular/core';@Directive({ selector: '[appChildRef]'})export class ChildRefDirective { constructor(public templateRef: TemplateRef) { }}
app-persons - html
Name: {{ person.name }}Money: {{ person.money }}200">
app-persons - ts
import { Component, ContentChild, OnInit } from '@angular/core';import { ChildRefDirective } from '../../../../directives/child-ref.directive';@Component({ selector: 'app-persons', templateUrl: './persons.component.html', styleUrls: ['./persons.component.scss']})export class PersonsComponent implements OnInit { persons: { name: string; money: number; }[] = [ { name: '杰克', money: 120 }, { name: '李莉', money: 210 }, { name: '张三', money: 170 }, ]; @ContentChild(ChildRefDirective, { static: true }) childRef!: ChildRefDirective; constructor() { } ngOnInit(): void { }}
使用
this is child ref content
效果图
多个条件内容投影
eg: 现在希望通过 persons 数据中的字段进行绑定内嵌的模板来显示
appChildRef 调整
import { Directive, Input, TemplateRef } from '@angular/core';@Directive({ selector: '[appChildRef]'})export class ChildRefDirective { // 接受定义模板名称-通过这个名称和 persons 中的render字段对应进行显示对应的模板内容 @Input() appChildRef!: string; constructor(public templateRef: TemplateRef) { }}
app-persons - html
Name: {{ person.name }}Money: {{ person.money }}
app-persons - ts
import { Component, ContentChild, ContentChildren, OnInit, QueryList } from '@angular/core';import { ChildRefDirective } from '../../../../directives/child-ref.directive';@Component({ selector: 'app-form-unit', templateUrl: './form-unit.component.html', styleUrls: ['./form-unit.component.scss']})export class FormUnitComponent implements OnInit { persons: { name: string; money: number; render?: string; }[] = [ { name: '杰克', money: 120, render: 'temp1' }, { name: '李莉', money: 210, render: 'temp2' }, { name: '张三', money: 170, render: 'temp3' }, ]; // @ContentChild(ChildRefDirective, { static: true }) childRef!: ChildRefDirective; @ContentChildren(ChildRefDirective) childrenRef!: QueryList; get tempRefs() { const aObj: any = {}; this.childrenRef.forEach(template => { const key: string = template.appChildRef; aObj[key] = template; }) return aObj; } constructor() { } ngOnInit(): void { }}
使用
{{index}}-{{person.name}}: this is temp1 {{index}}-{{person.name}}: this is temp2 {{index}}-{{person.name}}: this is temp3
效果图
感谢各位的阅读,以上就是"angular内容投影怎么实现"的内容了,经过本文的学习后,相信大家对angular内容投影怎么实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
内容
投影
模板
条件
学习
名称
字段
效果
效果图
张三
李莉
杰克
人员
单个
多个
就是
思路
情况
指令
数据
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发费如何走成本
魂师对决有几种服务器
驾驶员网络安全教育公司
高可用是增加服务器容错率吗
复旦大学有软件开发的专业吗
计算机数据库技术是什么
mysql数据库排序筛选
海报主题软件开发
基于c 连接达梦数据库
网络安全竞赛是什么时候
快聊服务器异常
数据库建设总结
苏州无线网络技术创新服务
网络安全有哪些主题
tomcat服务器特点
软件开发公司的英文名字
青少年网络安全怎么画
软件开发现在用的什么语言
陕西联想服务器维修调试多少钱
电梯软件开发流程
两个服务器调取一个数据库
关于 数据库 的特点
网络安全视频-看相预测
泰顺笑佑网络技术有限公司
t3财务软件如何连接服务器
确保网络安全到位
寄递物流网络安全培训
高桥北的服务器
政府部门落实网络安全的方案
计算机网络技术题目有哪些