我不是角度方面的专家,可能是解决这个问题的其他选择。但是,这就是我解决您的问题的方法:
我能够为每一行/每一行创建一个模型(一个对象),以便以后可以访问这些值以进行任何计算。然后在页面上呈现该模型。在每个更改事件上,我都会计算总和。只是一个想法,你可以扩展它。
// Initialize to 3 and create 3 models for it. A model
// has ID the name of the field and so on, you add other fields to it.
$scope.cntInputs = 3;
$scope.inputs = [];
for(var i=1; i <= $scope.cntInputs; i++){
$scope.inputs.push({id:i,pesco:'',zuccheri:''});
}
// call this when you want to increase the `Numero ingredienti`
$scope.addModel = function (){
$scope.inputs.push({id:$scope.cntInputs-1,pesco:'',zuccheri:''});
}
// call this whenever you have a change on each model.
$scope.calculate = function() {
var sum =0;
for(i=0; i <$scope.inputs.length; i++) {
sum += Number($scope.inputs[i].pesco)
$scope.inputs[i].zuccheri = 100; // XX * peso/100 calculate however you want
}
$scope.sum = sum;
};
/html正文
<body>
<div ng-controller="bxController" id="content">
<h1>Bilanciamento</h1>
Numero ingredienti: <input type="number" ng-change="addModel()" ng-model="cntInputs" placeholder="#Inputs"><br/>
<table>
<tr>
<th>Ingrediente</th>
<th>Peso</th>
<th>Zuccheri</th>
<th>Grassi</th>
<th>SML</th>
<th>Altri Solidi</th>
<th>Totale Solidi</th>
<th>Acqua</th>
</tr>
//just to display how its working {{inputs}}
<tr ng-repeat="c in inputs" type="text" name="myForm">
<td>
<select
ng-change="selectAction()"
ng-model="value"
ng-options="value.ingrediente for value in ingredienti">
<option>--</option>
</select>
</td>
<td>
<input ng-model="c.pesco" ng-change="calculate()" ></input>
</td>
<td> {{c.zuccheri | number}} g</td>
<td>{{value.grassi * peso / 100 | number}} g</td>
<td>{{value.sml * peso / 100 | number}} g</td>
<td>{{value.altrisolidi * peso / 100 | number}} g</td>
<td>{{value.totalesolidi * peso / 100 | number}} g</td>
<td>{{value.H2O * peso / 100 | number}} g</td>
</tr>
</table>
risultato:({{sum}})
</div>
</body>