我想用指令中創建的字段創建表單。數據的數據綁定正常工作,但驗證不起作用。如何驗證角度指令中的動態表單域?
這是HTML:
<body ng-controller="MainCtrl">
<h1>form</h1>
<form name="form">
<div ng-repeat="conf in config">
<div field data="data" conf="conf"></div>
</div>
</form>
<pre>{{data|json}}</pre>
</body>
控制器和現場指導:
var app = angular.module('plunker', []);
app.controller('MainCtrl', function($scope) {
$scope.data = {name: '', age: ''}
$scope.config = [
{field: 'name', required:true},
{field: 'age'}
];
});
app.directive('field', function ($compile) {
return {
scope: {
data: '=',
conf: '='
},
link: function linkFn(scope, element, attrs) {
// field container
var row = angular.element('<div></div>');
// label
row.append(scope.conf.field + ': ');
// field input
var field = angular.element('<input type="text" />');
field.attr('name', scope.conf.field);
field.attr('ng-model', 'data.' + scope.conf.field);
if (scope.conf.required) {
field.attr('required', 'required');
}
row.append(field);
// validation
if (scope.conf.required) {
var required = angular.element('<span>required</span>');
required.attr('ng-show',
'form.' + scope.conf.field + '.$error.required');
row.append(required);
}
$compile(row)(scope);
element.append(row);
}
}
});
問題是,現場name
驗證不起作用和驗證文本required
從未顯示。在ng-show
可能是form
在指令中是未知的。但我不知道如何將表單傳遞給field指令。你能幫我解決嗎?謝謝。
這裏是活代碼:http://plnkr.co/edit/j0xc7iV1Sqid2VK6rMDF?p=preview
我有同樣的問題作鬥爭。我在角源中發現了一個未公開的特性:'FormController'具有'$ addControl'和'$ removeControl'方法。我正在考慮利用這些方法從指令中動態地將控件添加到父'FormController'中。如果我成功了,會讓你知道。 – 2013-05-27 21:40:11