结构指令是什么?

结构指令通过添加和删除 DOM 元素来更改 DOM 布局。Angular 中两个常见的结构指令是 *ngIf 和 *ngFor 。
了解 * 号语法
* 号是语法糖,用于避免使用复杂的语法。我们以 *ngIf 指令为例:
(图片来源:https://netbasal.com/)
创建结构指令
首先,让我们了解如何创建一个结构指令。 接下来我们将要实现一个简单的 ngIf 指令。
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
@Directive({ selector: '[myNgIf]'})
export class MyNgIfDirective {
constructor(
private templateRef: TemplateRef<any>,
private viewContainer: ViewContainerRef) { }
@Input() set myNgIf(condition: boolean) {
if (condition) {
this.viewContainer.createEmbeddedView(this.templateRef);
} else {
this.viewContainer.clear();
}
}
}
我们可以按照以下方式使用我们的指令:
<div *myNgIf=”condition”></div>
下面我们来解释一下上面的代码。
TemplateRef
如名字所示,TemplateRef 用于表示模板的引用。
(图片来源:https://netbasal.com/)
ViewContainerRef
正如上面介绍的,模板中包含了 DOM 元素,但如果要显示模板中定义的元素,我们就需要定义一个插入模板中元素的地方。在 Angular 中,这个地方被称作容器,而 ViewContainerRef 用于表示容器的引用。那什么元素会作为容器呢?
Angular 将使用 comment 元素替换 template 元素,作为视图容器。
我们来看一个具体的示例:
@Component({
selector: 'my-app',
template: `
<div>
<h2 *myNgIf="condition">Hello {{name}}</h2>
<button (click)="condition = !condition">Click</button>
</div>
`,
})
export class App {
name: string;
condition: boolean = false;
constructor() {
this.name = 'Angular2'
}
}
以上代码成功运行后,浏览器的显示内容如下:
(图片来源:https://netbasal.com/)
ViewContainerRef 对象提供了 createEmbeddedView() 方法,该方法接收 TemplateRef 对象作为参数,并将模板中的内容作为容器 (comment 元素) 的兄弟元素,插入到页面中。
现在,你已经了解如何创建结构指令,接下来让我们看看两个具体的实例。
基于用户角色显示不同的内容
指令定义
@Directive({selector: '[ifRole]'})
export class IfRoleDirective {
user$ : Subscription;
@Input("ifRole") roleName : string;
constructor(
private templateRef : TemplateRef<any>,
private viewContainer : ViewContainerRef,
private authService : AuthService ) {}
ngOnInit() {
this.user$ = this.authService.user
.do(() => this.viewContainer.clear())
.filter(user => user.role === this.roleName)
.subscribe(() => {
this.viewContainer.createEmbeddedView(this.templateRef);
});
}
ngOnDestroy() {
this.user$.unsubscribe();
}
}
指令应用
<div *ifRole="'admin'"> Only for Admin </div> <div *ifRole="'client'"> Only for Client </div> <div *ifRole="'editor'"> Only for Editor </div>
创建 Range 指令
指令定义
import { Directive, Input, ViewContainerRef, TemplateRef } from '@angular/core';
@Directive({
selector: '[range]'
})
export class RangeDirective {
_range: number[];
@Input()
set range(value: number) {
this.vcr.clear();
this._range = this.generateRange(value[0], value[1]);
this._range.forEach(num => {
this.vcr.createEmbeddedView(this.tpl, {
$implicit: num
});
});
}
constructor(
private vcr: ViewContainerRef,
private tpl: TemplateRef<any>) { }
private generateRange(from: number, to: number): number[] {
var numbers: number[] = [];
for (let i = from; i <= to; i++) {
numbers.push(i);
}
return numbers;
}
}
以上示例中,我们在调用 createEmbeddedView() 方法时,设置了第二个参数 {$implicit: num} 。Angular 为我们提供了 let 模板语法,允许在生成上下文时定义和传递上下文。
这将允许我们引用 *range="[20,30]; let num" 模板中声明的变量。我们使用 $implicit 名称,因为我们不知道用户在使用这个指令时,会使用什么名字。
(图片来源:https://netbasal.com/)
指令应用
<h1>Your age:</h1>
<select>
<ng-container *range="[18, 80]; let num">
<option [ngValue]="num">{{num}}</option>
</ng-container>
</select>
<h1>Year:</h1>
<select>
<ng-container *range="[1998, 2016]; let num">
<option [ngValue]="num">{{num}}</option>
</ng-container>
</select>
以上代码成功运行后,浏览器的显示内容如下:
(图片来源:https://netbasal.com/)
总结
以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# angular2
# 指令
# angularjs2
# 结构型指令
# 详解Angular 自定义结构指令
# 详解angular2 控制视图的封装模式
# 浅谈Angular 观察者模式理解
# angular 服务的单例模式(依赖注入模式下)详解
# Angular指令之restict匹配模式的详解
# Angular中的结构指令模式及使用详解
# 让我们
# 我们可以
# 第二个
# 并将
# 为例
# 你已经
# 所示
# 这篇文章
# 谢谢大家
# 转换为
# 这将
# 绑定
# 创建一个
# 装在
# 使用这个
# 什么名字
# 包含了
# 有疑问
# 被称作
# MyNgIfDirective
相关文章:
如何选择可靠的免备案建站服务器?
建站主机选虚拟主机还是云服务器更好?
如何快速重置建站主机并恢复默认配置?
C#如何使用XPathNavigator高效查询XML
网站专业制作公司有哪些,做一个公司网站要多少钱?
制作网站的软件免费下载,免费制作app哪个平台好?
如何安全更换建站之星模板并保留数据?
建站主机类型有哪些?如何正确选型
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
建站之星Pro快速搭建教程:模板选择与功能配置指南
制作网站怎么制作,*游戏网站怎么搭建?
如何零基础开发自助建站系统?完整教程解析
西安大型网站制作公司,西安招聘网站最好的是哪个?
红河网站制作公司,红河事业单位身份证如何上传?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
建站之星如何修改网站生成路径?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
建站之星如何快速生成多端适配网站?
如何在Windows虚拟主机上快速搭建网站?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
学校建站服务器如何选型才能满足性能需求?
宝塔建站无法访问?如何排查配置与端口问题?
中山网站推广排名,中山信息港登录入口?
Swift中switch语句区间和元组模式匹配
如何快速查询网址的建站时间与历史轨迹?
建站之星2.7模板快速切换与批量管理功能操作指南
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
如何解决VPS建站LNMP环境配置常见问题?
c# Task.ConfigureAwait(true) 在什么场景下是必须的
建站之星如何实现PC+手机+微信网站五合一建站?
深圳网站制作平台,深圳市做网站好的公司有哪些?
定制建站是什么?如何实现个性化需求?
企业微网站怎么做,公司网站和公众号有什么区别?
在线制作视频的网站有哪些,电脑如何制作视频短片?
山东网站制作公司有哪些,山东大源集团官网?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
建站之星安装需要哪些步骤及注意事项?
C#如何序列化对象为XML XmlSerializer用法
Android自定义listview布局实现上拉加载下拉刷新功能
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
建站之星北京办公室:智能建站系统与小程序生成方案解析
家具网站制作软件,家具厂怎么跑业务?
如何快速搭建安全的FTP站点?
定制建站流程解析:需求评估与SEO优化功能开发指南
如何快速建站并高效导出源代码?
长沙做网站要多少钱,长沙国安网络怎么样?
手机网站制作与建设方案,手机网站如何建设?
子杰智能建站系统|零代码开发与AI生成SEO优化指南
*请认真填写需求信息,我们会在24小时内与您取得联系。