我決定寫一個自定義指令來幫助驗證我的輸入框。這個想法是,我將我的新花式nx-validate
指令添加到引導程序div.form-group
,它會檢查我的<input/>
是$dirty
還是$invalid
,並根據需要應用.has-success
或.has-error
類。AngularJS自定義表單驗證指令在我的模式下不起作用
由於某種奇怪的原因,我的指令在正常情況下完美工作,但添加的ng-class
在ui-bootstrap模式中完全被忽略。
的模式都和形式
<form name="mainForm">
<div class="row">
<div nx-validate class="form-group has-feedback col-lg-6 col-md-6 col-xs-12">
<label class="control-label">Green if long enough, red if not</label>
<input type="text" id="name" class="form-control" ng-model="property.name" required="required" ng-minlength="5"/>
(once touched I do change colour - happy face)
</div>
</div>
和我可愛的指令
nitro.directive("nxValidate", function($compile) {
return {
restrict: 'A',
priority: 2000,
compile: function(element) {
var node = element;
while (node && node[0].tagName != 'FORM') {
console.log (node[0].tagName)
node = node.parent();
}
if (!node) console.error("No form node as parent");
var formName = node.attr("name");
if (!formName) console.error("Form needs a name attribute");
var label = element.find("label");
var input = element.find("input");
var inputId = input.attr("id")
if (!label.attr("for")) {
label.attr("for", inputId);
}
if (!input.attr("name")) {
input.attr("name", inputId);
}
if (!input.attr("placeholder")) {
input.attr("placeholder", label.html());
}
element.attr("ng-class", "{'has-error' : " + formName + "." + inputId + ".$invalid && " + formName + "." + inputId + ".$touched, 'has-success' : " + formName + "." + inputId + ".$valid && " + formName + "." + inputId + ".$touched}");
element.removeAttr("nx-validate");
var fn = $compile(element);
return function($scope) {
fn($scope);
}
}
}
});
檢查出來的plunker 相同代碼:http://plnkr.co/edit/AjvNi5e6hmXcTgpXgTlH?
把你的按鈕在表單內。當我以掠奪者的例子做這件事的時候適用於我。 – juju