Angular中的FormGroup,如何在滚动DIV中滚动到第一个无效输入
创始人
2024-10-31 05:00:31
0

可以通过以下代码实现:

  1. 在HTML中添加一个滚动DIV:
  1. 在组件中获取这个滚动DIV的引用并在需要时滚动到第一个无效输入:
import { Component, ViewChild, ElementRef } from '@angular/core';
import { FormGroup, FormBuilder, Validators } from '@angular/forms';

@Component({
  selector: 'app-form',
  templateUrl: './form.component.html',
  styleUrls: ['./form.component.css']
})
export class FormComponent implements OnInit {
  form: FormGroup;
  
  // 获取滚动DIV的引用
  @ViewChild('scrollDiv') scrollDiv: ElementRef;

  constructor(private fb: FormBuilder) { }

  ngOnInit() {
    // 创建FormGroup并添加验证规则
    this.form = this.fb.group({
      // 表单的输入框组件以及规则
    });
  }

  onSubmit() {
    // 标记表单中的所有输入框为“脏”,这样它们将显示出验证消息
    this.markFormGroupTouched(this.form);

    // 如果表单中存在无效输入
    if (this.form.invalid) {
      // 获取第一个无效输入的DOM元素
      const invalidInput = this.scrollDiv.nativeElement.querySelector('input.ng-invalid');

      // 滚动到第一个无效输入
      invalidInput.scrollIntoView({ behavior: 'smooth' });
    }
  }

  markFormGroupTouched(formGroup: FormGroup) {
    Object.values(formGroup.controls).forEach(control => {
      control.markAsTouched();

      if (control instanceof FormGroup) {
        this.markFormGroupTouched(control);
      }
    });
  }
}

上述代码中,我们使用Angular的@ViewChild装饰器获取了滚动DIV的引用。然后在onSubmit()方法中,我们首先标记

相关内容

热门资讯

传递经验"pokem... 传递经验"pokemmo脚本辅助下载"开挂(平台)辅助平台了解有挂-玩家教程《详细加薇1367043...
推荐十款"掌中乐游戏... 推荐十款"掌中乐游戏辅助器"开挂(下载)辅助下载有挂教程-辅助教程;无需打开直接搜索加薇136704...
透视透视"决战卡五星... 透视透视"决战卡五星看牌器"开挂(下载)辅助下载有挂解惑-透视教程>>您好:软件加薇13670430...
实测必看"传送屋激k... 实测必看"传送屋激k万能辅助器app"开挂(安装)辅助安装有挂总结-AI教程 【无需打开直接搜索加薇...
教程攻略"新圣游脚本... 新圣游脚本下载是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微信...
科技分享"钱塘十水三... 您好:钱塘十水三挂件这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特...
玩家必看"广西友乐解... 大家好,今天小编来为大家解答广西友乐解码器下载安装这个问题咨询软件客服可以免费测试直接加微信(136...
透视软件"吉安中至小... 透视软件"吉安中至小程序辅助"开挂(软件)辅助软件有挂解惑-科技教程;无需打开直接搜索加(薇:136...
我来教教你"西兵辅助... 您好:这款西兵辅助器游戏是可以开挂的,确实是有挂的,很多玩家在这款西兵辅助器游戏中打牌都会发现很多用...
玩家必看科普"雀神广... 您好:这款雀神广东麻将透视视频游戏是可以开挂的,确实是有挂的,很多玩家在这款雀神广东麻将透视视频游戏...