dea*_*anN 10 javascript validation angularjs angularjs-directive
我有一个需要验证的表单.
表单包含许多部分,默认情况下会禁用其中一些部分.每个字段中的值都是正确的,但它违反了我的验证指令.例如,当它禁用时它应该包含0,但是当它可编辑时它应该包含其他内容.无论如何,我附加一个禁用指令给他们,并把它们放下.
当我提交表单(使用角度范围函数)时,if ($scope.sarfaslForm.$invalid)- >返回true.它说我检查$scope.sarfaslForm.$error列表时有两个无效字段.
在此博客之后,我实施了我的验证:http: //blog.yodersolutions.com/bootstrap-form-validation-done-right-in-angularjs/
在这个线程之后,我创建了一个指令来忽略我的一些禁用控件:
我对这个指令做了一个小改动:
.directive('hsDisableValidation', function() {
return {
require: '^form',
restrict: 'A',
link: function(scope, element, attrs,form) {
var control;
scope.$watch(function() {
return scope.$eval(attrs.hsDisableValidation);
}, function(value) {
if (!control) {
control = form[element[0].name];
//form[element.find("input").attr("name")];
}
if (value === false) {
form.$addControl(control);
angular.forEach(control.$error, function(validity, validationToken) {
form.$setValidity(validationToken, !validity, control);
});
} else {
form.$removeControl(control);
//In Here: I tried to $setValidity of controls to true, Remove Error List, and Remove Validator Function, but these things didn't worked out
}
});
}
}
})
Run Code Online (Sandbox Code Playgroud)
这里验证总是对我失败:PS:因为我在'text'类型的字段上使用它,我没有最小/最大值,只有最小/最大长度.我确定这不是问题,但我要包含这些代码以确保.
.directive('hsMinValue', function() {
return {
require: 'ngModel',
link: function (scope, elem, attr, ngModel) {
function isLesser(value) {
var minVal = parseInt(attr.hsMinValue);
return parseInt(value) < minVal;
}
function validate(value) {
var valid = !isLesser(value);
ngModel.$setValidity('minValue', valid);
return valid ? value : undefined;
}
ngModel.$parsers.unshift(function (value) {
ngModel.$setValidity('minValue', !isLesser(value));
return value;
});
ngModel.$formatters.unshift(function (value) {
ngModel.$setValidity('minValue', !isLesser(value));
return value;
});
}
}
});
Run Code Online (Sandbox Code Playgroud)
然后我保存:
saveSarfasl: function () {
$scope.$broadcast('show-errors-check-validity');
if ($scope.sarfaslForm.$invalid) { --> True :|
return;
}
//Stuffs
}
Run Code Online (Sandbox Code Playgroud)
编辑:请求詹姆斯,我把HTML和我的页面视图放在这里.
<div class="clearfix">
<form name="sarfaslForm" novalidate>
<table class="table-condensed">
<tbody>
<tr>
<td>
?? ?????
</td>
<td>
<table class="table-condensed">
<tbody>
<tr>
<td data-ng-if="View.FinYear.LenK != 0">
??
</td>
<td data-ng-if="View.FinYear.LenM != 0">
????
</td>
<td data-ng-if="View.FinYear.LenT1 != 0">
????? ??
</td>
<td data-ng-if="View.FinYear.LenT2 != 0">
????? ??
</td>
<td data-ng-if="View.FinYear.LenJ != 0">
???
</td>
</tr>
<tr>
<td data-ng-if="View.FinYear.LenK != 0">
<div class="form-group" hs-show-errors hs-show-success>
<input name="CodKol" type="text" hs-restrict-pattern="[^\d]*" maxlength="{{View.FinYear.LenK}}"
class="form-control input-sm"
data-ng-model="View.Kol" data-ng-disabled="View.Level!==1"
data-ng-blur="Events.codeChanged('k')"
data-ng-change="Events.setSarfaslCod()"
hs-disable-validation="View.Level!==1"
data-ng-required="true"
hs-min-value="1" />
<p class="help-block" ng-if="sarfaslForm.CodKol.$error.required">
?? ?? ?????? ?? ????
</p>
<p class="help-block" ng-if="sarfaslForm.CodKol.$error.minValue">
?? ?? ??? ????? ??? ????
</p>
</div>
</td>
<td data-ng-if="View.FinYear.LenM != 0">
<div class="form-group" hs-show-errors hs-show-success>
<input name="CodMoin" type="text" hs-restrict-pattern="[^\d]*" maxlength="{{View.FinYear.LenM}}"
class="form-control input-sm"
data-ng-model="View.Moin" data-ng-disabled="View.Level!==2"
data-ng-blur="Events.codeChanged('m')"
data-ng-change="Events.setSarfaslCod()"
hs-disable-validation="View.Level!==2"
data-ng-required
hs-min-value="1" />
<p class="help-block" ng-if="sarfaslForm.CodMoin.$error.required">
?? ???? ?????? ?? ????
</p>
<p class="help-block" ng-if="sarfaslForm.CodMoin.$error.minValue">
?? ???? ??? ????? ??? ????
</p>
</div>
</td>
<td data-ng-if="View.FinYear.LenT1 != 0">
<div class="form-group" hs-show-errors hs-show-success>
<input name="CodTafzil1" type="text" hs-restrict-pattern="[^\d]*" maxlength="{{View.FinYear.LenT1}}"
class="form-control input-sm"
data-ng-model="View.Tafzil1" data-ng-disabled="View.Level!==3"
data-ng-blur="Events.codeChanged('t1')"
data-ng-change="Events.setSarfaslCod()"
hs-disable-validation="View.Level!==3"
data-ng-required
hs-min-value="1" />
<p class="help-block" ng-if="sarfaslForm.CodTafzil1.$error.required">
?? ????? ?? ?????? ?? ????
</p>
<p class="help-block" ng-if="sarfaslForm.CodTafzil1.$error.minValue">
?? ????? ?? ??? ????? ??? ????
</p>
</div>
</td>
<td data-ng-if="View.FinYear.LenT2 != 0">
<div class="form-group" hs-show-errors hs-show-success>
<input name="CodTafzil2" type="text" hs-restrict-pattern="[^\d]*" maxlength="{{View.FinYear.LenT2}}"
class="form-control input-sm"
data-ng-model="View.Tafzil2" data-ng-disabled="View.Level!==4"
data-ng-blur="Events.codeChanged('t2')"
data-ng-change="Events.setSarfaslCod()"
hs-disable-validation="View.Level!==4"
data-ng-required
hs-min-value="1" />
<p class="help-block" ng-if="sarfaslForm.CodTafzil2.$error.required">
?? ????? ?? ?????? ?? ????
</p>
<p class="help-block" ng-if="sarfaslForm.CodTafzil2.$error.minValue">
?? ????? ?? ??? ????? ??? ????
</p>
</div>
</td>
<td data-ng-if="View.FinYear.LenJ != 0">
<div class="form-group" hs-show-errors hs-show-success>
<input name="CodJoz" type="text" hs-restrict-pattern="[^\d]*" maxlength="{{View.FinYear.LenJ}}"
class="form-control input-sm"
data-ng-model="View.Joz" data-ng-disabled="View.Level!==5"
data-ng-blur="Events.codeChanged('j')"
data-ng-change="Events.setSarfaslCod()"
hs-disable-validation="View.Level!==5"
data-ng-required
hs-min-value="1" />
<p class="help-block" ng-if="sarfaslForm.CodJoz.$error.required">
?? ??? ?????? ?? ????
</p>
<p class="help-block" ng-if="sarfaslForm.CodJoz.$error.minValue">
?? ??? ??? ????? ??? ????
</p>
</div>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
<tr>
<td>
????? ?????
</td>
<td ng-class="{'has-error':sarfaslForm.HsbNam.$invalid && sarfaslForm.HsbNam.$dirty}">
<div class="form-group" hs-show-errors hs-show-success>
<input name="HsbNam" type="text" data-ng-model="View.Sarfasl.HsbNam"
class="form-control input-sm"
data-ng-required="true" />
<p class="help-block" ng-if="sarfaslForm.HsbNam.$error.required">
??? ????? ?????? ?? ????
</p>
</div>
</td>
</tr>
<tr>
<td>
</td>
<td>
<div class="radio" hs-show-errors>
<label class="control-label">
<input type="radio" data-ng-model="View.Sarfasl.HsbKind" name="HsbKind" data-ng-value="'00'"
data-ng-required="true" />
??? ??? ????
</label>
</div>
<div class="radio" hs-show-errors>
<label class="control-label">
<input type="radio" data-ng-model="View.Sarfasl.HsbKind" name="HsbKind" data-ng-value="'11'"
data-ng-required="true" />
??? ??? ???
</label>
<p class="help-block" ng-if="sarfaslForm.HsbKind.$error.required">
?????? ??? ?? ????? ?????? ?? ????
</p>
</div>
</td>
</tr>
<tr>
<td>
</td>
<td>
<div class="radio" hs-show-errors>
<label class="control-label">
<input type="radio" data-ng-model="View.Sarfasl.Permanent" name="Permanent" data-ng-value="'1'"
data-ng-required="true" />
???? ????
</label>
</div>
<div class="radio" hs-show-errors>
<label class="control-label">
<input type="radio" data-ng-model="View.Sarfasl.Permanent" name="Permanent" data-ng-value="'0'"
data-ng-required="true" />
???? ????
</label>
<p class="help-block" ng-if="sarfaslForm.Permanent.$error.required">
?????? ??? ?? ????? ?????? ?? ????
</p>
</div>
</td>
</tr>
<tr>
<td>
</td>
<td>
<div class="radio" hs-show-errors>
<label class="control-label">
<input type="radio" data-ng-model="View.Sarfasl.AccessFlag" name="AccessFlag" data-ng-value="0"
data-ng-required="true" />
???? ???? ??? ?? ????? ????
</label>
</div>
<div class="radio" hs-show-errors>
<label class="control-label">
<input type="radio" data-ng-model="View.Sarfasl.AccessFlag" name="AccessFlag" data-ng-value="1"
data-ng-required="true" />
???? ??? ???? ??????? ??? ?? ????? ????
</label>
<p class="help-block" ng-if="sarfaslForm.AccessFlag.$error.required">
?????? ??? ?? ????? ?????? ?? ????
</p>
</div>
</td>
</tr>
<tr data-ng-if="View.Sarfasl.AccessFlag==1">
<td>
</td>
<td>
<table class="table table-bordered table-hover">
<thead>
<tr>
<th>
</th>
<th>
???????
</th>
</tr>
</thead>
<tbody>
<tr data-ng-repeat="user in View.UserList">
<td>
<div class="checkbox">
<label class="control-label">
<input type="checkbox" data-ng-model="user.Checked" data-ng-click="Events.userChecking(user)" />
</label>
</div>
</td>
<td>
{{user.UserID}}
</td>
</tr>
</tbody>
</table>
</td>
</tr>
<tr>
<td>
</td>
<td>
<!-- Hsb Types -->
<div class="checkbox">
<label class="control-label">
<input type="checkbox" data-ng-model="View.CheckBoxAllowRegisterLiability"
data-ng-click="Events.hsbTypeChecking(View.HsbTypes.AllowRegisterLiability, View.CheckBoxAllowRegisterLiability)" />
????? ??? ??????? ?? ????? ????? ????
</label>
</div>
<div class="checkbox">
<label class="control-label">
<input type="checkbox" data-ng-model="View.CheckBoxAllowRegisterCredits"
data-ng-click="Events.hsbTypeChecking(View.HsbTypes.AllowRegisterCredits, View.CheckBoxAllowRegisterCredits)" />
????? ??? ????????? ?? ????? ????? ????
</label>
</div>
<div class="checkbox">
<label class="control-label">
<input type="checkbox" data-ng-model="View.CheckBoxReminderShouldOnlyBeDebtor"
data-ng-click="Events.hsbTypeChecking(View.HsbTypes.ReminderShouldOnlyBeDebtor, View.CheckBoxReminderShouldOnlyBeDebtor)" />
????? ???? ??? ???? ?????? ????
</label>
</div>
<div class="checkbox">
<label class="control-label">
<input type="checkbox" data-ng-model="View.CheckBoxReminderShouldOnlyBeCreditor"
data-ng-click="Events.hsbTypeChecking(View.HsbTypes.ReminderShouldOnlyBeCreditor, View.CheckBoxReminderShouldOnlyBeCreditor)" />
????? ???? ??? ???? ???????? ????
</label>
</div>
</td>
</tr>
<tr>
<td>
???????
</td>
<td>
<textarea data-ng-model="View.Sarfasl.YadDasht" cols="200" rows="4" class="form-control input-sm">
</textarea>
</td>
</tr>
<tr>
<td>
</td>
<td>
<button type="button" class="btn btn-sm btn-primary" data-ng-click="Events.saveSarfasl()">
????? ???????
</button>
<a href="/#/Sarfasl" class="btn btn-sm btn-primary">
??????
</a>
</td>
</tr>
</tbody>
</table>
</form>
</div>
Run Code Online (Sandbox Code Playgroud)
当我使用它时,所有控件都可以自行查看每个控件.但是在我的函数中提交(提交按钮是正常按钮,但没有效果,但调用我的函数)后,我看到整体结果中的错误:
$scope.sarfaslForm.$invalid==>true
好吧,这是您的代码所做的假设。当您查看检查验证时,您正在检查 value === false 是否存在,否则您会将其添加到表单中,这不是您想要描述的逻辑。
您所说的是,无论值如何,如果该字段被禁用并设置为 0,我希望将其从表单中删除,那么如果该值为 false,我希望将其从表单中删除,否则验证表单。只需进行逻辑检查即可查看该字段是否已禁用,并将其从验证中删除。
if (value === 0) {
form.$removeControl(control);
} else if (value === false) {
form.$addControl(control);
angular.forEach(control.$error, function(validity, validationToken) {
form.$setValidity(validationToken, !validity, control);
});
} else {
form.$removeControl(control);
}
Run Code Online (Sandbox Code Playgroud)