使用 angular 快速入门应用程序 ( https://github.com/angular/quickstart/blob/master/README.md )。使用角度 2.1.1
使用 *ngFor,列表的第一项不会出现在页面上。我在控制台中没有收到任何错误,但是在 ngOnInit 中看到以下控制台日志输出teacher.component.ts:
Erty
Dave
Sarah
Walter
undefined
Run Code Online (Sandbox Code Playgroud)
最后一个“未定义”意味着数组的第一个元素正在被重新定义,但我不知道为什么。
这是输出的屏幕截图——代码贴在下面。
请注意,重复块中缺少第一个老师,但不在 json 数组中。
代码:
老师.component.ts:
import { Component, Input } from "@angular/core";
@Component({
selector: 'teacher',
template: `
<p>Teacher {{index}}: {{teacherName}}</p>
`
})
export class TeacherComponent {
@Input() teacherName: string;
@Input() index: number;
ngOnInit() {
console.log(this.teacherName);
}
}
Run Code Online (Sandbox Code Playgroud)
app.module.ts:
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { TeacherComponent } from './teacher.component';
@NgModule({
imports: [ BrowserModule ],
declarations: [TeacherComponent, AppComponent ],
bootstrap: [ AppComponent, TeacherComponent ]
})
export class AppModule { }
Run Code Online (Sandbox Code Playgroud)
app.component.ts:
import { Component } from '@angular/core';
import { TeacherComponent } from "./teacher.component";
@Component({
selector: 'my-app',
template: `<h1>CodeCraft Learning Angular!</h1>
<pre>{{teachers | json}}</pre>
<teacher *ngFor="let t of teachers; let i = index" [teacherName]="t" [index]="i"></teacher>
`
})
export class AppComponent {
public teachers: string[] = [
"Erty",
"Dave",
"Sarah",
"Walter"
];
}
Run Code Online (Sandbox Code Playgroud)
感谢您的帮助!
问题是您在 app.module 中引导教师组件,它被视为入口组件,这使我们的目的第一次渲染中断。
此更改将使其正确呈现:
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { TeacherComponent } from './teacher.component';
@NgModule({
imports: [ BrowserModule ],
declarations: [TeacherComponent, AppComponent ],
bootstrap: [ AppComponent ]
})
export class AppModule { }
Run Code Online (Sandbox Code Playgroud)
这里有一些关于引导什么的阅读https://angular.io/docs/ts/latest/cookbook/ngmodule-faq.html#!#q-bootstrap_vs_entry_component
| 归档时间: |
|
| 查看次数: |
1759 次 |
| 最近记录: |