[Angular] inputタグに指定したchangeイベントで再度同じファイルを選択してもイベントを検知する
3185 ワード
inputタグにchangeイベントを指定し、ファイルの選択を検知してなにかするよくある処理です。
同じファイルを選択してもイベントの検知をしたい際の解決策となります。
同じファイルを選択してもイベント検知できない例
example.component.html
<input type="file" (change)="changeFile($event)" />
example.component.ts
export class ExampleComponent {
changeFile($event: Readonly<Event>): void {
// 処理
}
}
ファイル選択ダイアログでファイルを選択した後、同じファイルを選択してもchangeイベントは検知できません。
解決策
example.component.html
<input #fileInput type="file" (change)="changeFile($event)" />
example.component.ts
export class ExampleComponent {
@ViewChild('fileInput') fileInput: ElementRef;
changeFile($event: Readonly<Event>): void {
// 処理
this.fileInput.nativeElement.value = '';
}
}
ViewChild
でrefを取得し、直接valueを初期化することでchangeイベントが同じファイルを選択されても検知できるようになります。
Author And Source
この問題について([Angular] inputタグに指定したchangeイベントで再度同じファイルを選択してもイベントを検知する), 我々は、より多くの情報をここで見つけました https://qiita.com/kozzzz/items/cc4e02b4f8daccacbcd9著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .