Angular2 PrimeNg Dropdown在未定义时显示值

时间:2017-03-20 18:58:36

标签: javascript angular primeng

使用libaray作为参考:https://www.primefaces.org/primeng/#/dropdown

问题是select显示第一个选项,但根据后端,字段未定义。

  <p-dropdown [options]="avaliableTemplates" [style]="{'width':'100%'}" required placeholder="Select Title" filter [(ngModel)]="selectedTemplate" name="selectedTemplate"></p-dropdown>

enter image description here

以下是检查更改的代码:

 @ViewChild('createCampaignForm') form;    
 this.form.control.valueChanges.debounceTime(1000).subscribe(values => this.doValidation(values));

以下是我分配avaliableTamplates

的方法
 this.campaignService.getTemplates(this.authService).subscribe(x => {
                this.avaliableTemplates = [];
                for (var i = 0; i < x.length; i++) {
                    this.avaliableTemplates.push({
                        label: x[i].title,
                        value: x[i].id
                    });
                }
            });

基于上面的内容,似乎下拉列表不是默认为undefined,而是数组中的第一个元素。但它甚至不承认在后端选择了第一个元素。

2 个答案:

答案 0 :(得分:0)

我从Prime那里挖掘了文档,并在这里尝试了一些东西。我注意到你应该添加一个默认选项,或者它总是选择默认的第一个选项:

this.campaignService.getTemplates(this.authService).subscribe(x => {
    this.avaliableTemplates = x.map((e) => { 
        return { label: e.title, value: e.id}; 
    });

    // Add the default option at position 0
    this.avaliableTemplates.splice(0, 0, {label: 'Select something', value: null});
});

答案 1 :(得分:0)

<p-dropdown placeholder=" "></p-dropdown>