我需要一种方法来遍历 AngularJS 表单的注册控件。本质上,我正在尝试获取所有 $dirty 控件,但没有控件数组(FormController 除了包含控件本身之外,还有许多不同的属性/功能 - 每个都是它自己的对象)。
我一直在查看源代码,发现controls
FormController 中有一个数组,正是我要查找的数组。有没有办法访问这个值,或者扩展 FormController 以包含一个返回这个controls
数组的函数?
编辑:Plnkr演示
此外,我意识到从技术上讲,我可以检查密钥字符串中的第一个字符是否为“$”,但我想避免这种情况,以防 FormController/directive 在未来版本的 Angular 中发生变化。
编辑2:另一个澄清:我的目标是能够确定哪些特定字段是$dirty,是否通过循环遍历整个控件列表(不包括$dirty、$invalid、$error、$name、和其他存在于 Form 对象中的属性)或通过扩展 FormController 并创建一个函数,该函数仅返回当前脏的控件(并且不等于它们的起始值)
编辑3:我正在寻找的解决方案需要适用于不同结构的表单/模型。示波器上的模型是通过 AJAX 生成的,因此它们的结构已经设置好(我想避免为我已经通过 AJAX 接收的所有数据硬编码一个新结构)。此外,我希望在多个表单/模型中使用此表单提交过程,它们中的每一个都有不同的 JSON 结构——因为它们适用于我们对象模型中的不同实体。这就是为什么我选择寻求一种方法来访问controls
FormController 中的对象(我将从FormController
下面发布代码),因为它是唯一可以获得所有字段的平面数组的地方。
function FormController(element, attrs) {
var form = this,
parentForm = element.parent().controller('form') || nullFormCtrl,
invalidCount = 0, // used to easily determine if we are valid
errors = form.$error = {},
controls = [];
// init state
form.$name = attrs.name || attrs.ngForm;
form.$dirty = false;
form.$pristine = true;
form.$valid = true;
form.$invalid = false;
parentForm.$addControl(form);
// Setup initial state of the control
element.addClass(PRISTINE_CLASS);
toggleValidCss(true);
// convenience method for easy toggling of classes
function toggleValidCss(isValid, validationErrorKey) {
validationErrorKey = validationErrorKey ? '-' + snake_case(validationErrorKey, '-') : '';
element.
removeClass((isValid ? INVALID_CLASS : VALID_CLASS) + validationErrorKey).
addClass((isValid ? VALID_CLASS : INVALID_CLASS) + validationErrorKey);
}
/**
* @ngdoc function
* @name ng.directive:form.FormController#$addControl
* @methodOf ng.directive:form.FormController
*
* @description
* Register a control with the form.
*
* Input elements using ngModelController do this automatically when they are linked.
*/
form.$addControl = function(control) {
controls.push(control);
if (control.$name && !form.hasOwnProperty(control.$name)) {
form[control.$name] = control;
}
};
/**
* @ngdoc function
* @name ng.directive:form.FormController#$removeControl
* @methodOf ng.directive:form.FormController
*
* @description
* Deregister a control from the form.
*
* Input elements using ngModelController do this automatically when they are destroyed.
*/
form.$removeControl = function(control) {
if (control.$name && form[control.$name] === control) {
delete form[control.$name];
}
forEach(errors, function(queue, validationToken) {
form.$setValidity(validationToken, true, control);
});
arrayRemove(controls, control);
};
// Removed extra code
}
如您所见,表单本身具有controls
私有可用的数组。我想知道是否有办法让我扩展,FormController
以便我可以公开该对象?或者创建一个公共函数,以便我至少可以查看私有数组?