[英]Angular2 Tutorial: How is the ID variable in this section being auto incremented?
在Angular2教程的这一部分中,有一些功能可以向数组添加新项目。 添加后,ID会自动递增,但我无法确定哪个进程正在执行此操作。
我知道Arrays.push()返回数组的长度,是自动插入Hero类中的id变量的长度吗?
在hero.services.ts中有一段代码来创建一个英雄:
create(name: string): Promise<Hero> {
return this.http
.post(this.heroesUrl, JSON.stringify({name: name}), {headers: this.headers})
.toPromise()
.then(res => res.json().data)
.catch(this.handleError);
}
在heroes.component.ts中有添加
add(name: string): void {
name = name.trim();
if (!name) { return; }
this.heroService.create(name)
.then(hero => {
this.heroes.push(hero);
this.selectedHero = null;
});
}
本教程使用angular 2 in-memory-web-api库。 它正在处理正在对英雄网址发布的帖子。 可以在第328行的文件中看到处理程序:
https://github.com/angular/in-memory-web-api/blob/master/in-memory-backend.service.js
在该处理程序内部,id通过调用genId函数生成,该函数的实现位于第257行:
InMemoryBackendService.prototype.genId = function (collection) {
// assumes numeric ids
var maxId = 0;
collection.reduce(function (prev, item) {
maxId = Math.max(maxId, typeof item.id === 'number' ? item.id : maxId);
}, null);
return maxId + 1;
};
它使用InMemoryDbService
的默认功能。
您可以在app/in-memory-dataservice.ts
找到mock / reference
import { InMemoryDbService } from 'angular2-in-memory-web-api
可以在此处找到服务的角度源: in-memory-backend.service.t(第326行)
在服务的create
方法中,调用web api并将英雄的名称发布到它,返回一个包含id
和name
字段的完整英雄对象。
所以我想增量和“节约”发生在那个网络api的窗帘后面。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.