我找不到满足部分或所有这些需求的答案。这就是我想出的。
可能有更好的方法,所以请分享您的想法。
我正在使用 Angularjs 1.3.0-beta.8
我有一个带有多嵌套指令的表单,所有指令都包含输入、选择等……这些元素都包含在 ng-repeat 和动态字符串值中。
这是如何使用指令:
<form name="myFormName">
<nested directives of many levels>
ex: <input ng-repeat=(index, variable) in variables" type="text"
my-name="{{ variable.name + '/' + 'myFormName' }}"
ng-model="variable.name" required />
ex: <select ng-model="variable.name" ng-options="label in label in {{ variable.options }}"
my-name="{{ variable.name + '/' + 'myFormName' }}"
</select>
</form>
注意:如果您需要序列化输入表,您可以添加和索引字符串连接;这就是我所做的。但是,动态名称输入意味着您可能不知道表单输入的名称,那么您将如何调用 $scope.formName.??????。您可以迭代 $scope.formName 对象以获取与某个值匹配的键。这意味着像这样的字符串连接:
my-name="{{ dynamicString + hello + '/' + 'myFormName' }}"
然后在 $scope.myFormName 中,您只需遍历对象并收集包含“hello”的任何键即可找到任何表单输入名称。
app.directive('myName', function(){
var myNameError = "myName directive error: "
return {
restrict:'A', // Declares an Attributes Directive.
require: 'ngModel', // ngModelController.
link: function( scope, elem, attrs, ngModel ){
if( !ngModel ){ return } // no ngModel exists for this element
// check myName input for proper formatting ex. something/something
checkInputFormat(attrs);
var inputName = attrs.myName.match('^\\w+').pop(); // match upto '/'
assignInputNameToInputModel(inputName, ngModel);
var formName = attrs.myName.match('\\w+$').pop(); // match after '/'
findForm(formName, ngModel, scope);
} // end link
} // end return
function checkInputFormat(attrs){
if( !/\w\/\w/.test(attrs.rsName )){
throw myNameError + "Formatting should be \"inputName/formName\" but is " + attrs.rsName
}
}
function assignInputNameToInputModel(inputName, ngModel){
ngModel.$name = inputName
}
function addInputNameToForm(formName, ngModel, scope){
scope[formName][ngModel.$name] = ngModel; return
}
function findForm(formName, ngModel, scope){
if( !scope ){ // ran out of scope before finding scope[formName]
throw myNameError + "<Form> element named " + formName + " could not be found."
}
if( formName in scope){ // found scope[formName]
addInputNameToForm(formName, ngModel, scope)
return
}
findForm(formName, ngModel, scope.$parent) // recursively search through $parent scopes
}
});
这应该可以处理许多您不知道表单在哪里的情况。或者,您可能有嵌套的表单,但出于某种原因,您想将此输入名称附加到两个表单上?好吧,只需传入要附加输入名称的表单名称即可。
我想要的是一种将动态值分配给我永远不会知道的输入的方法,然后只需调用 $scope.myFormName.$valid。
这可能有点矫枉过正,1.3+ 中存在更好的解决方案。我在我有的时候找不到它。这现在对我有用。
祝你好运!希望这对某人有所帮助!!!!