Angular响应式表单中如何将焦点设置到动态创建的输入框?
创始人
2024-10-30 08:00:47
0

可以通过使用 ViewChild 装饰器获取到动态创建的输入框所对应的 FormGroupDirective,然后在必要时通过调用 ElementRef 中的 focus() 方法即可将焦点设置到该输入框中。

示例代码:

在 .html 文件中,通过 ngFor 创建动态表单控件:

在 .ts 文件中,使用 ViewChild 装饰器获取动态创建的输入框所对应的 FormGroupDirective 并设置焦点:

import { Component, OnInit, ViewChild, ElementRef } from '@angular/core';
import { FormGroup, FormControl } from '@angular/forms';

@Component({...})
export class MyComponent implements OnInit {

  @ViewChild(FormGroupDirective) formGroupDirective: FormGroupDirective;
  controls = ['firstName', 'lastName'];

  form = new FormGroup({
    firstName: new FormControl(),
    lastName: new FormControl()
  });

  constructor(private elem: ElementRef) {}

  ngOnInit(): void {}

  setFocus(input: HTMLInputElement): void {
    this.formGroupDirective.form.patchValue({
      [input.name]: input.value.trim()
    });
    this.elem.nativeElement.querySelector(`[formControlName="${input.name}"]`).focus();
  }

}

相关内容

热门资讯

透视步骤!wepoker插件辅... 透视步骤!wepoker插件辅助(HHpoker机器人)确实存在有辅助工具(哔哩哔哩)1、下载好we...
透视演示!hhpoker辅助软... 透视演示!hhpoker辅助软件是真的么(WePoKer俱乐部)总是有辅助神器(哔哩哔哩)1、hhp...
透视操作!德州私人局怎么透视(... 透视操作!德州私人局怎么透视(AApoker插件)好像是有辅助软件(哔哩哔哩)1.德州私人局怎么透视...
透视练习!wpk俱乐部怎么作必... 透视练习!wpk俱乐部怎么作必弊(WePoKer钻石)好像真的是有辅助攻略(哔哩哔哩)wpk俱乐部怎...
透视技法!菠萝辅助器免费版的特... 透视技法!菠萝辅助器免费版的特点(HHpoker透视挂)一贯有辅助方法(哔哩哔哩)1)菠萝辅助器免费...
透视课程!hhpoker辅助挂... 透视课程!hhpoker辅助挂(WPK模拟器)果然存在有辅助教程(哔哩哔哩)hhpoker辅助挂破解...
透视手筋!hh poker软件... 透视手筋!hh poker软件(AApoker设置)切实是真的有辅助插件(哔哩哔哩)hh poker...
透视法门!wepoker辅助软... 透视法门!wepoker辅助软件价格(WPK有透视)切实是有辅助方法(哔哩哔哩)1、不需要AI权限,...
透视机巧!有没有人wepoke... 透视机巧!有没有人wepoker(AApoker辅助器)好像有辅助方法(哔哩哔哩)1、进入游戏-大厅...
透视技法!wepoker有用吗... 透视技法!wepoker有用吗(AApoker控制牌)都是是真的有辅助神器(哔哩哔哩)1、超多福利:...