gpt4 book ai didi

angularjs - 在 Controller 中调用 angular $setValidity

转载 作者:行者123 更新时间:2023-12-03 07:56:39 28 4
gpt4 key购买 nike

我有一个输入字段和一个按钮,用户可以在其中输入要进行地理定位的地址。它是更大表单的一部分,但我希望在他们按下“映射”按钮而不是最终表单提交时处理该字段的有效性。如何将此字段设置为无效?调用 $setValidity导致未定义/非函数错误。

形式位:

<form name="myForm">
<input type="text" name="addy" ng-model="addy">
<a ng-click="geoCode()">Map it!</a>
<span class="error" ng-hide="myForm.addy.$invalid">Bad field</span>
....
</form>

Controller :
$scope.addy = null

// This is a more complex async function trimmed down to essentials
$scope.geoCode = function() {
$scope.addy.$setValidity('unique', false);
});

我还希望该字段只检查一次。因此,如果他们输入一个地址并且没有按下 Map it 按钮,那么它会在提交时被检查,但是如果他们确实按下了 Map 按钮并且字段是有效的,那么它将不会再次通过异步函数运行。关于如何最好地处理这个问题的建议?

最佳答案

如果您想设置 validity在 Controller 中的输入字段中,您可以简单地传递表单并访问您的输入,就像您在标记中一样。我还包括一个工作示例:

var app = angular.module('form-example', []);

app.controller('FormCtrl', function($scope) {
var vm = this;

vm.geoCode = function(form) {
form.addy.$setValidity('unique', false);
};
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.min.js"></script>

<form ng-app="form-example" name="myForm" ng-controller="FormCtrl as vm">
<input type="text" name="addy" ng-model="vm.addy">
<a ng-click="vm.geoCode(myForm)">Map it!</a>
<span class="error" ng-hide="myForm.addy.$invalid">Bad field</span>
</form>

关于angularjs - 在 Controller 中调用 angular $setValidity,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30787683/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com