在Angular中,可以通过监听表单控件的值变化来调用函数。以下是一个示例代码,演示了如何在FormArray中更改下拉列表时调用函数:
首先,创建一个带有表单的组件。在这个例子中,我们假设有一个FormArray,其中包含多个FormGroup,每个FormGroup中都有一个下拉列表控件。
import { Component, OnInit } from '@angular/core';
import { FormArray, FormControl, FormGroup } from '@angular/forms';
@Component({
selector: 'app-my-form',
templateUrl: './my-form.component.html',
styleUrls: ['./my-form.component.css']
})
export class MyFormComponent implements OnInit {
form: FormGroup;
ngOnInit() {
this.form = new FormGroup({
items: new FormArray([])
});
// 添加初始的FormGroup
this.addItem();
}
get items(): FormArray {
return this.form.get('items') as FormArray;
}
addItem() {
const item = new FormGroup({
dropdown: new FormControl(''),
// 其他表单控件
});
// 监听下拉列表的值变化
item.get('dropdown').valueChanges.subscribe(value => {
this.onDropdownChange(value);
});
this.items.push(item);
}
onDropdownChange(value: any) {
// 在这里根据下拉列表的值执行相应的逻辑
console.log('Dropdown value changed:', value);
}
}
在模板中,我们通过使用*ngFor
指令来循环遍历FormArray中的每个FormGroup,并为每个FormGroup中的下拉列表添加一个change
事件监听器。
这样,每当下拉列表的值发生变化时,都会调用onDropdownChange
方法,并传递选中的值作为参数。在onDropdownChange
方法中,你可以根据选中的值执行你需要的逻辑。
希望这个示例能够帮助你解决问题!