Angular2 @Input() 数组未被设置
创始人
2024-10-22 06:01:00
0

在Angular 2中,如果你使用@Input()装饰器来接收一个数组作为输入属性,并且没有设置默认值,当父组件没有传递该属性时,该数组将是未定义的。在这种情况下,你可以使用NgOnChanges生命周期钩子和简单的条件检查来处理这个问题。

下面是一个示例代码:

在子组件中,声明一个输入属性,并使用@Input()装饰器:

import { Component, Input, OnChanges, SimpleChanges } from '@angular/core';

@Component({
  selector: 'child-component',
  template: `
    
{{ item }}
` }) export class ChildComponent implements OnChanges { @Input() items: any[]; ngOnChanges(changes: SimpleChanges): void { if (changes['items'] && changes['items'].currentValue) { this.items = changes['items'].currentValue; } } }

在父组件中,使用子组件并传递一个数组:

import { Component } from '@angular/core';

@Component({
  selector: 'parent-component',
  template: `
    
  `
})
export class ParentComponent {
  myItems: any[];

  constructor() {
    // 设置myItems数组
    this.myItems = ['Item 1', 'Item 2', 'Item 3'];
  }
}

在这个例子中,当父组件没有传递items属性时,子组件的ngOnChanges方法会被调用。在ngOnChanges方法中,我们检查changes对象是否包含items属性,并且当前值不为null或undefined。如果满足条件,我们将当前值赋给子组件的items属性。

这样,在子组件的模板中,我们就可以安全地遍历并显示items数组的内容。

相关内容

热门资讯

推出新举措!wepoker透视... 推出新举措!wepoker透视脚本下载(透视)乐胡陇南摆叫辅助器(原来有辅助辅助器)-哔哩哔哩1、乐...
透视好友房!佛手大菠萝13道挂... 透视好友房!佛手大菠萝13道挂哪里(透视)新珊瑚大厅辅助(一直真的是有辅助修改器)-哔哩哔哩新珊瑚大...
近年来!德州hhpoker脚本... 近年来!德州hhpoker脚本(透视)新上游辅助器(都是存在有辅助插件)-哔哩哔哩1、进入游戏-大厅...
透视教学!wepoker俱乐部... 透视教学!wepoker俱乐部辅助(透视)吉祥填大坑插件(其实真的是有辅助工具)-哔哩哔哩1、点击下...
透视软件!哈糖大菠萝软件下载(... 透视软件!哈糖大菠萝软件下载(透视)雀神麻雀充运势用吗(其实是真的辅助修改器)-哔哩哔哩一、雀神麻雀...
今年以来!佛手在线有挂吗(透视... 今年以来!佛手在线有挂吗(透视)789大菠萝攻略(都是有辅助工具)-哔哩哔哩1、很好的工具软件,可以...
在玩家背景下!wepoker有... 在玩家背景下!wepoker有插件吗(透视)微信闲来辅助神器免费(真是是真的辅助下载)-哔哩哔哩微信...
透视透视挂!aapoker插件... 透视透视挂!aapoker插件(透视)广东雀神智能插件是真的(好像存在有辅助神器)-哔哩哔哩1、金币...
一直以来!智星菠萝可以辅助吗(... 一直以来!智星菠萝可以辅助吗(透视)小闲辅助神器(其实是真的辅助工具)-哔哩哔哩一直以来!智星菠萝可...
透视好友房!黑侠破解wepok... 透视好友房!黑侠破解wepoker(透视)兴动互娱辅助(好像有辅助安装)-哔哩哔哩1.兴动互娱辅助 ...