我有这个单元格模板,它将对象的值显示到 span 元素中,或者,如果行正在编辑,则显示输入中的值。
<ng-template ngx-datatable-cell-template let-rowIndex="rowIndex" let-row="row" let-value="value">
<span
*ngIf="!editing[rowIndex]">
{{value}}
</span>
<input
#myInput
autofocus
(blur)="setValue($event, value , row)"
*ngIf="editing[rowIndex]"
type="text"
[value]="value"
/>
</ng-template>
当我单击编辑按钮时,我需要聚焦并选择文本。没问题。我有
@ViewChild('myInput') myInput;
和
private focusInput(){
this.myInput.nativeElement.focus();
this.myInput.nativeElement.select();
}
问题是,如果我需要“同时”编辑 2 行,在单击第 1 行编辑按钮后,被选中并聚焦,但是当我单击第 2 行的编辑按钮时,第一个输入再次获得焦点。我认为是有角度地找到第一个可用的#myinput 元素并将它们聚焦,因为如果我首先单击第 5 行,它会正确聚焦,并且当任何先前的行被标记为编辑时,行为都很好。
即使模板中存在其他#myinput,我如何才能使每一行都有效?