Standardmäßig sind die Daten der ersten Person required="true"
, aber das Formular der übrigen Person ist required="true"
basierend auf einem seiner Felder gefüllt oder nicht.Wie wird ng-required wahr gemacht, wenn eines der zugehörigen Objektfelder gefüllt ist?
Das aktuelle Problem des Snippets ist, dass es nicht gültig ist, wenn die letzte Person ein Feld ausgefüllt hat.
Demo: http://plnkr.co/edit/WUpybR1tNq5QFjlTB2E7?p=preview
var app = angular.module('plunker', []);
app.controller('MainCtrl', function($scope) {
$scope.person = [{isRequired: true}, {isRequired: false}, {isRequired: false}, {isRequired: false}];
$scope.members = {};
$scope.submitForm = function() {
console.clear();
if (typeof $scope.members != 'undefined' && Object.keys($scope.members).length) {
var numMembers = Object.keys($scope.members).length;
for (i = 0; i < numMembers; i++) {
if (Object.keys($scope.members[i]).length <= 2) {
$scope.person[i].isRequired = true;
}
}
} else {
$scope.person = [{isRequired: true}, {isRequired: false}, {isRequired: false}, {isRequired: false}];
}
}
});
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" />
<script src="https://code.angularjs.org/1.4.8/angular.js" data-semver="1.4.9"></script>
<div ng-app="plunker" ng-controller="MainCtrl" class="container">
<form name="myForm" ng-submit="submitForm(myForm.$valid)" novalidate>
<h4>First person</h4>
<div class="form-group" ng-class="{ 'has-error' : (myForm.$submitted && myForm.firstnameOne.$invalid) || (!myForm.firstnameOne.$pristine && myForm.firstnameOne.$invalid)}">
<label>First Name</label>
<input type="text" class="form-control" name="firstnameOne" placeholder="First Name" ng-model="members[0].fname" ng-required="person[0].isRequired">
</div>
<div class="form-group" ng-class="{ 'has-error' : (myForm.$submitted && myForm.lastnameOne.$invalid) || (!myForm.lastnameOne.$pristine && myForm.lastnameOne.$invalid)}">
<label>Last Name</label>
<input type="text" class="form-control" name="lastnameOne" placeholder="Last Name" ng-model="members[0].lname" ng-required="person[0].isRequired">
</div>
<h4>Second person</h4>
<div class="form-group" ng-class="{ 'has-error' : (myForm.$submitted && myForm.firstnameSecond.$invalid) || (!myForm.firstnameSecond.$pristine && myForm.firstnameSecond.$invalid)}">
<label>First Name</label>
<input type="text" class="form-control" name="firstnameSecond" placeholder="First Name" ng-model="members[1].fname" ng-required="person[1].isRequired">
</div>
<div class="form-group" ng-class="{ 'has-error' : (myForm.$submitted && myForm.lastnameSecond.$invalid) || (!myForm.lastnameSecond.$pristine && myForm.lastnameSecond.$invalid)}">
<label>Last Name</label>
<input type="text" class="form-control" name="lastnameSecond" placeholder="Last Name" ng-model="members[1].lname" ng-required="person[1].isRequired">
</div>
<h4>Last person</h4>
<div class="form-group" ng-class="{ 'has-error' : (myForm.$submitted && myForm.firstnameThird.$invalid) || (!myForm.firstnameThird.$pristine && myForm.firstnameThird.$invalid)}">
<label>First Name</label>
<input type="text" class="form-control" name="firstnameThird" placeholder="First Name" ng-model="members[2].fname" ng-required="person[2].isRequired">
</div>
<div class="form-group" ng-class="{ 'has-error' : (myForm.$submitted && myForm.lastnameThird.$invalid) || (!myForm.lastnameThird.$pristine && myForm.lastnameThird.$invalid)}">
<label>Last Name</label>
<input type="text" class="form-control" name="lastnameThird" placeholder="Last Name" ng-model="members[2].lname" ng-required="person[2].isRequired">
</div>
<button type="submit" class="btn btn-primary">Submit</button>
</form>
<br><hr>
<h4>Data</h4>
<pre>{{members | json}}</pre>
<h4>Validation</h4>
<pre>{{person | json}}</pre>
</div>
Vielen Dank für die Lösung. Haben Sie eine Idee, wie Sie das erforderliche Formular aus dem dritten Formular zurücksetzen können, wenn ich das Feld lösche? – Muhammed
@MuhammedAthimannil Sie überprüfen gerade Validierungsstatus des Formulars auf einem einzelnen Ereignis - Formular absenden. Wenn Sie die erforderliche Bedingung zurücksetzen möchten, wenn Sie Ihr Feld löschen, müssen Sie den Validierungsstatus für die Feldänderung überprüfen, z. B. eine 'ngChange'-Anweisung für Ihre Eingabe festlegen, die den Validierungsstatus bei Feldänderungen überprüft. – iulian
die Sache ist, dass gefüllt erste Felder und dritte Feld nur Nachname so das Ergebnis ist dritte Felder sind 'erforderlich' dann einfach nur den Test aus dem Nachnamen des dritten Feldes gelöscht. Ich würde "Required = false" erwarten, wenn Sie das Formular senden hoffe, Sie verstanden die Frage – Muhammed