JavaScript   发布时间:2022-04-16  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Angular 2.x学习教程之结构指令详解大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

结构指令是

什么

结构指令通过添加和删除 DOM 元素来更改 DOM 布局。Angular 中两个常见的结构指令是 *ngIf*ngFor

了解 * 号语法

* 号是语法糖,用于避免使用复杂的语法。我们以 *ngIf 指令为例:

Angular 2.x学习教程之结构指令详解

(图片来源:https://netbasal.com/)

  • Angular 把 host (宿主元素) 包装在 template 标签里面
  • Angular 将 ngIf 转换为属性绑定 - [ngIf]

创建结构指令

首先,让我们了解如何创建一个结构指令。 接下来我们将要实现一个简单的 ngIf 指令。

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

@Directive({ SELEctor: '[myNgIf]'})
export class MyNgIfDirective {

constructor(
private templateRef: TemplateRef,private viewContainer: ViewContainerRef) { }

@Input() set myNgIf(condition: Boolean) {
if (condition) {
this.viewContainer.createEmbeddedView(this.templateRef);
} else {
this.viewContainer.clear();
}
}
}

我们可以按照以下方式使用我们的指令:

下面我们来解释一下上面的代码。

TemplateRef

如名字所示,TemplateRef 用于表示模板的引用。

Angular 2.x学习教程之结构指令详解

(图片来源:https://netbasal.com/)

ViewContainerRef

正如上面介绍的,模板中包含了 DOM 元素,但如果要显示模板中定义的元素,我们就需要定义一个插入模板中元素的地方。在 Angular 中,这个地方被称作容器,而 ViewContainerRef 用于表示容器的引用。那什么元素会作为容器呢?

Angular 将使用 comment 元素替换 template 元素,作为视图容器。

我们来看一个具体的示例:

{ SELEctor: 'my-app',template: `

Hello {{name}}

`,}) export class App { name: String; condition: Boolean = false; constructor() { this.name = 'Angular2' } }

以上代码成功运行后,浏览器的显示内容如下:

Angular 2.x学习教程之结构指令详解

(图片来源:https://netbasal.com/)

ViewContainerRef 对象提供了 createEmbeddedView() 方法,该方法接收 TemplateRef 对象作为参数,并将模板中的内容作为容器 (comment 元素) 的兄弟元素,插入到页面中。

现在,你已经了解如何创建结构指令,接下来让我们看看两个具体的实例。

基于用户角色显示不同的内容

指令定义

{SELEctor: '[ifRole]'}) export class IfRoleDirective { user$ : Subscription; @Input("ifRole") rolename : String;

constructor(
private templateRef : TemplateRef,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="'client'">
Only for Client

<div *ifRole="'editor'">
Only for Editor

创建 Range 指令

指令定义

{ Directive,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) { }

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 名称,因为我们不知道用户在使用这个指令时,会使用什么名字。

Angular 2.x学习教程之结构指令详解

(图片来源:https://netbasal.com/)

指令应用

Your age:

Year:

以上代码成功运行后,浏览器的显示内容如下:

Angular 2.x学习教程之结构指令详解

(图片来源:https://netbasal.com/)

总结

以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对菜鸟教程的支持。

大佬总结

以上是大佬教程为你收集整理的Angular 2.x学习教程之结构指令详解全部内容,希望文章能够帮你解决Angular 2.x学习教程之结构指令详解所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:angular2指令结构型指令
猜你在找的JavaScript相关文章
其他相关热搜词更多
phpJavaPython程序员load如何string使用参数jquery开发安装listlinuxiosandroid工具javascriptcap