是否可以将索引变量用作数组指针?
<div *ngFor="let item of messageSplit[i]; let i = index">
<td>{{item}}</td>
</div>
我没有收到任何错误,但没有显示任何内容。 我已经尝试在component.ts中调用一个函数,如下所示,但这导致了很多其他问题。
<div *ngFor="let item of messageSplit[incrementArray()]">
<td>{{item}}</td>
</div>
incrementArray() {
return this.counter++;
}
以下是我的component.ts文件中的相关方法,以便进一步了解问题
messageSplit = new Array;
loadMessages() {
this.messageSplit = [];
const currentUserId = +this.authService.decodedToken.nameid;
this.userService.getMessages(this.authService.decodedToken.nameid,
this.messageContainer)
.do(messages => {
_.each(messages, (message: Message) => {
if (this.messageContainer !== 'unread') {
if (this.compareArray(message) !== true) {
this.splitMessages(message);
}
}
if (message.isRead === false && message.recipientId === currentUserId)
{
this.userService.markAsRead(currentUserId, message.id);
}
});
}, error => {
console.log('');
}, () => {
console.log(this.messageSplit);
this.splitReady = true;
})
.subscribe((res: Message[]) => {
this.messages = res;
});
}
compareArray(message) {
let count = 0;
for (let i = 0; i < this.messageSplit.length; i++) {
if (message.content !== null) {
if (this.messageSplit[i] === message.content.split(',')) {
count = count + 1;
}
}
}
if (count > 0) {
return true;
}
return false;
}
splitMessages(message) {
if (message.content !== null) {
this.messageSplit.push(message.content.split(','));
}
}
increment() {
return this.counter++;
}
答案 0 :(得分:0)
ngFor仅适用于数组。 messageSplit [i]只返回一个元素,你将无法迭代它(除非messageSplit [i]返回一个数组)。请提供messageSplit的详细信息。这将有助于回答这个问题。