本篇文章主要的介绍了关于angularjs中的三种指令类型,分别是哪三种呢,还是让本篇文章来告诉你吧,还有这三种怎么使用的都在这里。现在我们一起来看看吧
在Angular2中有三种类型的指令(Directive) ,如下:
1. 属性型指令 - 改变元素显示和行为的指令。例如:NgStyle …
2. 结构型指令 - 通过添加和移除DOM元素来改变DOM结构的指令。例如:NgFor, NgIf …
3. 组件 — 拥有模板的指令。
一、属性指令(ngStyle ,ngClass)
NgStyle
绑定一个有形如CSS属性名:value的对象,其中value为具体的css样式,eg:
<p [ngStyle]="{color: 'white','background-color':'green'}"></<p>
注意,在 ngStyle 的说明中,我们对 background-color 使用了单引号,但却没有对 color 使用。这是为什么呢?因为 ngStyle 的参数是一个JavaScript对象,而color 是一个合法的键,不需要引号。但是在 background-color 中,连字符是不允许出现在对象的键名当中的,除非它是一个字符串,因此使用了引号。通常情况下,尽量不会对对象的键使用引号,除非不得不用。
//动态使用
<span [ngStyle]="{color: color}">{{ color }} text</span>
//判断添加
<p [ngStyle]="{'background-color':username === 'zxc' ? 'green' : 'red' }"></<p>
NgClass
利用NgClass指令,可以同时添加或移除多个类。NgClass绑定一个有形如CSS类名:value的对象,其中value的值是一个布尔型的值,当value值为true时,添加对应类型的模板元素,反之则移除。
//基本用法
<p [ngClass]="{bordered: false}">此时p不包含bordered 类名</p> <p [ngClass]="{bordered: true}">此时p含有bordered 类名</p>
//判断
<i [ngClass]="{green: isAddr, red: !isAddr}"></i>
二、结构型指令(ngIf ,ngFor ,ngSwitch)
NgIf
指定绑定一个布尔型的表达式,当表达式返回true时,可以在DOM树节点上添加一个元素及其子元素,反之被移除。
如果表达式的结果返回的是一个假值,那么元素会从DOM上被移除。
下面是一些例子:
<p *ngIf="false"></p> //不显示 <p *ngIf="a > b"></p>// <p *ngIf="str == 'yes'"></p> <p *ngIf="myFunc()"></p>
NgFor
NgFor指令可以实现重复执行某些操作来展示数据。NgFor指令支持一个可选的index索引。
它的语法是 *ngFor="let item of items" :
let item 语法指定一个用来接收 items 数组中每个元素的(模板)变量。
items 是来自组件控制器的一组项的集合
this.cities = ['厦门', '福州', '漳州']; <p class="ui list" *ngFor="let c of cities">{{ c }}</p>
获取索引
在迭代数组时,我们可能也要获取每一项的索引。
我们可以在 ngFor 指令的值中插入语法 let idx = index 并用分号分隔开,这样就可以获取索引了。
<p class="ui list" *ngFor="let c of cities; let num = index">{{ num+1 }} . {{ c }}</p>
结果如下:
1.厦门
2.福州
3.漳州
ngSwitch
有时候你需要根据一个给定的条件来渲染不同的元素。
遇到这种情况时,你可能会像下面这样多次使用 ngIf :
<p class="container"> <p *ngIf="myVar == 'A'">Var is A</p> <p *ngIf="myVar == 'B'">Var is B</p> <p *ngIf="myVar == 'C'">Var is C</p> <p *ngIf="myVar != 'A' && myVar != 'B' && myVar != 'C'">Var is something else</p> </p>
对于这种情况,Angular引入了 ngSwitch 指令。(想看更多就到PHP中文网AngularJS开发手册中学习)
NgSwitch:绑定到一个返回控制条件的值表达式
NgSwitchCase:绑定到一个返回匹配条件的值表达式
NgSwitchDefault:用于标记默认元素的属性,是可选的。如果我们不用它,那么当 myVar 没有匹配到任何期望的值
时就不会渲染任何东西。
使用ngSwitch 指令来重写上面的例子:
<p class="container" [ngSwitch]="myVar"> <p *ngSwitchCase="'A'">Var is A</p> <p *ngSwitchCase="'B'">Var is B</p> <p *ngSwitchCase="'C'">Var is C</p> <p *ngSwitchDefault>Var is something else</p> </p>
三、组件
属性型指令的创建至少需要一个带有@Directive装饰器修饰的控制器类。@Directive装饰器指定了一个选择器名称,用于指出与此指令相关联的属性的名字。
接下来,开始创建一个简单的属性型指令,该指令的功能是,user-quotation-view.component.html页面刷新时获取.quotation-area的最小高度。
1、首先我们确认好指令名字,quotationArea
<p class="quotation-area" quotationArea></p>
把这个指令作为一个属性应用到一个DOM元素上,也就是我们需要为我们定一个这个指令找到一个宿主元素。
2、之后我们创建一个quotationArea.directive.tss文件,其代码结构如下:
import {Component, Directive, ElementRef, OnInit} from '@angular/core'; @Directive({ selector: '[quotationArea]'}) export class QuotationAreaDirective implements OnInit { el:ElementRef; constructor(el: ElementRef) { this.el = el; } ngOnInit() { const $el = $(this.el.nativeElement); const windowHeight = document.documentElement.clientHeight; //获取窗口高度 const bar=document.getElementsByClassName('bar-nav')[0] const barHeight =bar.clientHeight; const heightValue=windowHeight - barHeight; $el.css('height',(heightValue) + 'px'); } }
3、接下来 我们需要在module.ts中来显示的声明我们自己定义的指令,以便Angualr在解析模板时,能够正确的识别我们自己定一个指令。
import {QuotationAreaDirective} from './user-quotation/user-quotation-view/quotationArea.directive'; declarations: [QuotationAreaDirective]
结果如图:
好了,本篇文章到这就结束了(想看更多就到PHP中文网AngularJS使用手册中学习),有问题的可以在下方留言提问
以上是Angular中的Directive(指令)知道吗?这里有angularjs的三种directive指令详解的详细内容。更多信息请关注PHP中文网其他相关文章!

本篇文章带大家继续angular的学习,简单了解一下Angular中的独立组件(Standalone Component),希望对大家有所帮助!

本篇文章带大家深入了解一下angular的状态管理器NgRx,介绍一下NgRx的使用方法,希望对大家有所帮助!

Angular项目过大,怎么合理拆分它?下面本篇文章给大家介绍一下合理拆分Angular项目的方法,希望对大家有所帮助!

怎么自定义angular-datetime-picker格式?下面本篇文章聊聊自定义格式的方法,希望对大家有所帮助!

本篇文章带大家了解一下Angular中的独立组件,看看怎么在Angular中创建一个独立组件,怎么在独立组件中导入已有的模块,希望对大家有所帮助!

本篇文章带大家了解一下依赖注入,介绍一下依赖注入解决的问题和它原生的写法是什么,并聊聊Angular的依赖注入框架,希望对大家有所帮助!
![如何解决“[Vue warn]: Failed to resolve directive”错误](https://img.php.cn/upload/article/000/887/227/169252525940934.jpg)
如何解决“[Vuewarn]:Failedtoresolvedirective”错误Vue.js是一款流行的JavaScript框架,它提供了很多有用的功能来开发交互式的Web应用程序。其中一个特性是指令(Directive),它可以用于扩展HTML元素的功能或添加特定的行为。然而,有时候在使用指令时可能会遇到一个错误:“[Vuewarn]:F

本篇文章带大家深入了解一下angular中的几个特殊选择器:host、:host-context、::ng-deep,希望对大家有所帮助!


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver CS6
视觉化网页开发工具

WebStorm Mac版
好用的JavaScript开发工具