下面是一个使用FormArray对多个文件进行文件阅读器的Angular解决方法的代码示例:
import { Component } from '@angular/core';
import { FormBuilder, FormGroup, FormArray } from '@angular/forms';
@Component({
selector: 'app-file-reader',
templateUrl: './file-reader.component.html',
styleUrls: ['./file-reader.component.css']
})
export class FileReaderComponent {
fileForm: FormGroup;
constructor(private formBuilder: FormBuilder) {
this.fileForm = this.formBuilder.group({
files: this.formBuilder.array([])
});
}
get fileArray() {
return this.fileForm.get('files') as FormArray;
}
addFile() {
this.fileArray.push(this.formBuilder.control(''));
}
removeFile(index: number) {
this.fileArray.removeAt(index);
}
readFile(event: any, index: number) {
const file = event.target.files[0];
const reader = new FileReader();
reader.onload = (e: any) => {
this.fileArray.at(index).setValue(e.target.result);
};
reader.readAsText(file);
}
onSubmit() {
console.log(this.fileForm.value);
// 进行其他操作,例如上传文件等
}
}
这个示例中,我们使用FormGroup和FormArray来动态添加和删除文件输入控件,并使用FileReader来读取文件内容并将其存储在FormArray中。在提交表单时,我们可以通过fileForm.value获取所有文件的内容,然后进行进一步的操作,如上传文件等。