Angular2 内置指令 NgFor 和 NgIf 详解

http://www.jb51.net/article/89781.htm

在这一章节中,我们来学习如何使用Angular2来展示数据,以及如何使用它的内置指令NgForNgIf

首先要确保你有一个可以运行起来的Angular2的样例程序,最好就是我们上一章节中完成的那个QuickStart小项目或者你自己根据官网上面的步骤完成的QuickStart小项目,因为我们的讲解都是在那个基础上来进行的;然后让我们开始下面的快乐旅程吧.

因为我们的这一系列的文章都是使用的Typescript所以在看下面的内容之前你最好可以看一下Typescript或者ES6的类,它们的网址分别是Typescript,ES6;如果以前你学过Java或者C++这种类似的面向对象的语言的话,那么学习这里的类就很轻松了;这里面的类基本上和那些语言中的类是相似的.

上一节中我们在app.component.ts中导出了一个空的类,那么下面我们就要开始填充它,让它变得丰满起来.首先我们给这个AppComponent类(组件)添加三个属性,分别是name,age,fruit;就像下面这样:

?


1

2

3

4

5

export class AppComponent {

  username = ‘dreamapple‘;

  age = 22;

  fruit = ‘apple‘

}

上面的写法其实只是一种简写的形式,实际上完整的写法应该是这样的:

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

export class AppComponent {

  //username = ‘dreamapple‘;

  //age = 22;

  //fruit = ‘apple‘

  username: string;

  age: number;

  fruit: string;

 

  constructor() {

    this.username = ‘dreamapple‘;

    this.age = 22;

    this.fruit = ‘apple‘;

  }

}

然后我们要修改我们的模板了,因为我们在模板中要使用较多的HTML,所以我们要使用反引号来包裹住我们的HTML片段;我们的装饰器函数如下所示:

?


1

2

3

4

5

6

7

8

@Component({

  selector: ‘my-app‘,

  template:`

    <p>My name is: {{username}}</p>

    <p>My age is: {{age}}</p>

    <p>My favorite fruit is: {{fruit}}</p>

  `

})

当然我们也可以使用装饰器函数中元数据对象的templateUrl配置选项,如下所示:

?


1

2

3

4

5

6

7

8

9

@Component({

  selector: ‘my-app‘,

  //template:`

  //  <p>My name is: {{username}}</p>

  //  <p>My age is: {{age}}</p>

  //  <p>My favorite fruit is: {{fruit}}</p>

  //`,

  templateUrl: ‘app/templates/app-template.html‘

})

其中app/templates/app-template.html表示的是程序的根目录app(而不是angular2-travel)下的templates文件夹下的app-template.html文件,然后将我们之前写的HTML片段复制过去就好了.

从上面的过程中,我们可以看到Angular2显示数据依然使用的是Angular1惯用的双大括号;它作为一个插值符号,在这个插值符号出现的地方就是我们要显示的数据的地方.接下来我们要学习使用NgFor这个内置指令了,熟悉Angular1的同学应该很容易就上手这个指令,因为NgFor和ng-repeat基本是一样的;它用来循环一个可迭代的对象,一般情况下会是一个数组.

接下来我们给AppComponent再添加一个属性fruitsList,如下所示:

?


1

2

3

4

5

6

export class AppComponent {

  username = ‘dreamapple‘;

  age = 22;

  fruitsList = [‘apple‘, ‘orange‘, ‘pear‘, ‘banana‘];

  fruit = this.fruitsList[0]; // 这里要使用 this.fruitsList[0]

}

我们需要注意的地方是那个有注释的地方,我们必须使用this.fruitsList来指代上面我们已经定义好的属性,如果使用fruitsList的话,Angular就不知道它表示是什么.
接下来我们要循环这个水果数组了,看看如何在模板中表示吧.

?


1

2

3

4

5

6

7

8

9

10

11

@Component({

  selector: ‘my-app‘,

  template:`

    <p>My name is: {{username}}</p>

    <p>My age is: {{age}}</p>

    <ul>

      <li *ngFor="let fruit of fruitsList">{{fruit}}</li>

    </ul>

    <p>My favorite fruit is: {{fruit}}</p>

  `

})

上面的代码中有几个地方是需要注意的地方,首先我们使用了*ngFor而不是ngFor,这里的*是不能够去掉的;如果去掉的话那么我们的程序不会报错,但是我们只循环出来了数组的第一项.关于为何要加*,你可以详细的看看这里模板语法;当然我们可以在*ngFor表达式的后面写一些能够帮助我们展示每一项索引的操作,可以像下面这样:

<li *ngFor="let fruit of fruitsList; let i =
index;">{{i}}-{{fruit}}</li>
上面的模板代码有一些需要注意的地方,首先要知道*ngFor后面跟的是表达式,所以我们可以写一些简单的表达式,帮助我们更好地进行循环;还有我们使用了let关键词,增加了块级作用域,使我们的这些变量都限定在*ngFor这个循环块中.好啦,如果你想更多地了解*ngFor,你可以看一下官方关于NgFor的API.

接下来要介绍的这个指令是NgIf,当然这个指令和Angular1的ng-if指令基本上是相似的,根据后面表达式的值决定要不要在DOM上添加或者移除一个元素.

看看我们是如何在模板使用这个指令的:

<p *ngIf="fruitsList.length > 3">fruitsList‘s length is bigger than
3</p>
<p *ngIf="fruitsList.length <= 3">fruitsList‘s length is
not bigger than
3</p>
首先要指出的是,和使用*ngFor一样,我们使用了*ngIf;然后我们可以在*ngIf后面写上一个表达式,这个表达式被期望的返回结果是Boolean类型的值;然后*ngIf指令会根据这个表达式的值决定要不要在DOM上添加或者移除它掌控的这个元素.

既然我们使用了Typescript,我们就可以使用很多新的特性,比如说使用类去构建实例;接下来我们来使用Fruit类来构建我们的水果实例.首先我们在app文件夹下创建一个新的文件夹,就叫它classes吧,然后我们创建一个Fruit.ts文件,在这里面我们书写Fruit类的代码:

?


1

2

3

4

5

6

export class Fruit{

  constructor(

    public name:string,

    public price: number

  ){}

}

解释一下上面的代码,我们使用了构造函数,然后在构造函数里面声明了这个对象的两个属性;一个是name,另一个是price,我们使用构造函数里面的name:string,和price:
number参数来创建和初始化这个对象的属性.接下来我们就可以在我们的程序中使用这个类了;

首先在app.component.ts中引入这个类:

import {Fruit} from
‘./classes/Fruits‘;
然后在AppComponent中使用Fruit类来初始化我们的水果列表:

?


1

2

3

4

5

6

7

8

9

10

11

12

export class AppComponent {

  username = ‘dreamapple‘;

  age = 22;

  fruitsList = [

    new Fruit(‘apple‘, 20),

    new Fruit(‘orange‘, 30),

    new Fruit(‘pear‘, 40),

    new Fruit(‘banana‘, 50)

  ];

  //noinspection TypescriptUnresolvedVariable

  fruit = this.fruitsList[0].name; // 这里要使用 this.fruitsList[0]

}

然后也要改一下我们的模板:

复制代码
代码如下:

<li *ngFor="let fruit of fruitsList; let
i = index;">{{i}}-{{fruit.name}}-{{fruit.price}}</li>

最后的结果应该是下面这个样子:

最后不得不说,无论是ES6,还是Typescript都让我感觉到了有种写Java感觉;这也算有利有弊吧,好处肯定是增加了代码的可读性,使程序更加容易维护,也更容易写出大型的项目,让团队协作也非常的便利;当然也有它的一些不足,不足主要是增加了大家的学习成本;当然一切向前看呀.

如对本文有疑问,请提交到交流社区,广大热心网友会为你解答!! 点击进入社区

您可能感兴趣的文章:

时间: 2024-07-29 18:00:23

Angular2 内置指令 NgFor 和 NgIf 详解的相关文章

Win7下的内置FTP组件的设置详解

在局域网中共享文件,FTP是比较方便的方案之一.Win7内部集成了FTP,只是设置起来颇费一番功夫.着文以记之. 一.安装FTP组件 由于Win7默认没有安装FTP组件.故FTP的设置第一步就是安装FTP组件 点击:控制面板—>程序和功能—>打开或关闭Windows功能.勾选“FTP服务器”及“FTP服务”“FTP扩展性”,点击“确定”,安装FTP组件.如下图所示 二.添加FTP站点 点击:控制面板—>管理工具.选中“Internet信息服务(IIS)管理器”,如图 双击“Interne

[Form Builder]内置函数execute_trigger、do_key详解

转:http://yedward.net/?id=82 1.execute_trigger:用来运行一个指定的触发器,常用来运行用户自定义的触发器. 语法:procedure execute_trigger(trigger_name varchar2),其中trigger_name是指定的一个有效的用户命名的触发器.execute_trigger无法指定调用的trigger的范围,所以forms一般会从最底层的触发器开始,然后向上处理,所以我见过一些用到execute_trigger的时候,它调

vue内置指令详解——小白速会

指令 (Directives) 是带有 v- 前缀的特殊属性,职责是,当表达式的值改变时,将其产生的连带影响,响应式地作用于 DOM. 内置指令 1.v-bind:响应并更新DOM特性:例如:v-bind:href  v-bind:class  v-bind:title  等等 主要用法是绑定属性,动态更新HTML元素上的属性: <a v-bind:href="url">...</a> <!-- 缩写 --> <a :href="ur

ng-book札记——内置指令

Angular提供了一些内置指令(directive),这些添加在HTML元素(element)上的特性(attribute)可以赋予更多的动态行为. NgIf ngIf指令用于在某个条件下显示或者隐藏元素,该条件取决于传入指令的表达式的结果. <div *ngIf="false"></div> <!-- 永远不显示 --> <div *ngIf="a > b"></div> <!-- a大于b

Angular中的内置指令和自定义指令

NG中的指令,到底是什么(what)? 为什么会有(why)?以及怎样使用(how)? What: 在NG中,指令扩展HTML功能,为 DOM 元素调用方法.定义行为绑定数据等. Why: 最大程度减少DOM操作,实现数据绑定,与业务逻辑进行交互. How: 指令主要分为两种:内置指令和自定义指令,通过下面的例子,简单记录一下如何去使用. 内置指令 在官方API文档上罗列了很多指令,内置指令可以分为:普通指令 和 事件指令,他们都是作用于HTML之上的,通过添加属性的方式来实现的.简单看一下一些

AngularJS内置指令集合

ng-model 将表单控件和当前作用域的属性进行绑定 代码如下: <input type="text" ng-model="someModel.someProperty" /><br>{{someModel.someProperty}} ng-init 该指令被调用时会初始化内部作用域.这个指令一般会出现在比较小的应用中,比如给个demo什么的... 代码如下: <div ng-init="job='fighter'&quo

AngularJS内置指令

内置指令 所有的内置指令的前缀都为ng,不建议自定义指令使用该前缀,以免冲突.首先从一些常见的内置指令开始.先列出一些关键的内置指令,顺便简单说说作用域的问题. ng-model 将表单控件和当前作用域的属性进行绑定,这么解释似乎也不太正确.但先不要管咬文嚼字,用起来倒是易懂,例如: 代码如下: <input type="text" ng-model="someModel.someProperty" /><br>{{someModel.som

AngularJS中的内置指令

AngularJS可以把模版编写成HTML的形式,利用指令来拓展HTML标签,增加声明式语法来实现想做的任何事情.AngularJS的内置指令包括渲染指令.事件指令和节点指令. 渲染指令 ng-bind: <p ng-bind="something"></p> 相当于: <p>{{something}}</p> ng-bind-template: 如果用ng-bind-template,则相当于: <p ng-bind-templa

AngularJS内置指令 ng-xxx

指令,我将其理解为AngularJS操作HTML element的一种途径. 由于学习AngularJS的第一步就是写内置指令ng-app以指出该节点是应用的根节点,所以指令早已不陌生. 这篇日志简单记录了一些内置指令,先使用起来,再谈一些有趣的东西. 内置指令 所有的内置指令的前缀都为ng,不建议自定义指令使用该前缀,以免冲突.首先从一些常见的内置指令开始.先列出一些关键的内置指令,顺便简单说说作用域的问题. ng-model 将表单控件和当前作用域的属性进行绑定,这么解释似乎也不太正确.但先