在验证完成之前,AngularJS 表单$valid设置为 true

AngularJS form $valid set to true before validation completes

本文关键字:表单 valid 设置 true AngularJS 验证      更新时间:2023-09-26

我在页面的左侧导航中显示一个验证符号,以指示表单是否有效。当我最初加载页面时,表单的 $valid 属性设置为 true,然后最终它变为 false(因为它应该被赋予检索到的输入数据)。结果是我的验证符号从有效闪烁到无效。 有什么办法可以防止这种情况吗?目前,验证符号与$scope上的有效属性相关联,该属性在监视中设置。是否有任何逻辑可以添加到手表中以检查表单是否尚未完成初始化或验证?谢谢!

这是我目前的手表代码。有效属性在几个不同的监视周期后从未定义变为 true 再到 false。

$scope.$watch( 'sections.' + section.sectionName + '.sectionForm.$valid', function( valid ) {
    section.valid = valid;
}, true);

以及显示验证符号的 HTML:

<span ng-class="{ 'fa fa-check': section.valid,
    'fa fa-warning': !section.valid}">
</span>

我认为问题是$watch函数。第一次将"section.valid"设置为未定义。您无需手动观看。每个表单指令创建 FormController 的一个实例。因此,您可以直接在视图中检查表单有效性。

<span ng-class="{'fa fa-check': sectionFormName.$valid, 'fa fa-warning': sectionFormName.$invalid}"></span>