全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

结构指令是什么

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

了解 * 号语法

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

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

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

创建结构指令

首先,让我们了解如何创建一个结构指令。 接下来我们将要实现一个简单的 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 


相关文章: 如何选择美橙互联多站合一建站方案?  建站ABC备案流程中有哪些关键注意事项?  建站之星价格显示格式升级,你的预算足够吗?  详解jQuery中基本的动画方法  湖北网站制作公司有哪些,湖北清能集团官网?  Swift中switch语句区间和元组模式匹配  中山网站制作网页,中山新生登记系统登记流程?  已有域名如何快速搭建专属网站?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  建站之星如何开启自定义404页面避免用户流失?  ,如何利用word制作宣传手册?  制作网站怎么制作,*游戏网站怎么搭建?  如何选择靠谱的建站公司加盟品牌?  如何用IIS7快速搭建并优化网站站点?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  建站主机选哪家性价比最高?  如何在Golang中使用encoding/gob序列化对象_存储和传输数据  深圳网站制作平台,深圳市做网站好的公司有哪些?  相册网站制作软件,图片上的网址怎么复制?  建站之星收费标准详解:套餐费用及年费价格表一览  建站主机选购指南:核心配置优化与品牌推荐方案  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  已有域名建站全流程解析:网站搭建步骤与建站工具选择  如何设计高效校园网站?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  如何通过虚拟主机空间快速建站?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?  如何用花生壳三步快速搭建专属网站?  如何用AWS免费套餐快速搭建高效网站?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  外贸公司网站制作哪家好,maersk船公司官网?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  高性能网站服务器部署指南:稳定运行与安全配置优化方案  建站之星与建站宝盒如何选择最佳方案?  网站制作网站,深圳做网站哪家比较好?  如何快速查询网站的真实建站时间?  大型企业网站制作流程,做网站需要注册公司吗?  javascript中的try catch异常捕获机制用法分析  制作企业网站建设方案,怎样建设一个公司网站?  如何选购建站域名与空间?自助平台全解析  建站10G流量真的够用吗?如何应对访问高峰?  建站主机与虚拟主机有何区别?如何选择最优方案?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  已有域名和空间如何快速搭建网站?  ,sp开头的版面叫什么?  建站之星CMS五站合一模板配置与SEO优化指南  北京网站制作的公司有哪些,北京白云观官方网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。