Я пытаюсь визуализировать динамический массив массива (при нажатии «+» должен быть добавлен новый), но всегда, когда я помещаю какой-либо файл в поле ввода сообщения («Nenhum Arquivo Selecionado», что означает «Файл не работает»). 't Exist ") остается на экране.
data:image/s3,"s3://crabby-images/1ae35/1ae355ef66e02ce05b96eaf28b22aa2635ee453e" alt="enter image description here"
Однако, если я проверю информацию на this.filterForm.get ('Documents'), строка заполнится правильно.
У кого-нибудь есть предложение исправить эту ошибку?
protocolo.component.ts
items: FormArray;
filterForm = new FormGroup({
IdProtocolo: new FormControl(),
Documentos: this.formBuilder.array([ this.createItem() ]
);
ngOnInit() {
this.items = this.filterForm.get('Documentos') as FormArray;
}
createItem(): FormGroup{
return this.formBuilder.group({
filename: '',
filetype: '',
value: ''
})
}
addItem(){
this.items.push(this.createItem());
}
removeItem(index){
if(this.items.length > 1) {
this.items.removeAt(index);
}
}
onFileChange(event: any, index: any) {
let reader = new FileReader();
if(event.target.files && event.target.files.length > 0) {
let file = event.target.files[0];
reader.readAsDataURL(file);
this.items.at(index).patchValue({
filename: file.name,
filetype: file.type,
value: (reader.result as string).split(',')[1]
})
}
}
protocolo.component.html
<div *ngFor="let item of filterForm.value.Documentos; let i = index;">
<div class="row" style="margin-bottom: 10px;">
<div class="col-md-4">
<input type="file" formControlName="Documentos" (change)="onFileChange($event, i)">
</div>
<div class="col-md-8">
<button class="btn btn-success-tce" (click)="addItem()">+</button>
<button class="btn btn-success-tce" (click)="removeItem(i)"style="margin-left: 5px">-</button>
</div>
</div>