我最近开始使用AngularJS,我想我遇到了一个奇怪的错误。
首先,这是一些工作代码:
看法:
<body ng-controller="MainCtrl">
<form name="form">
<div ng-repeat="phone in phoneNumbers">
<input ng-model="phone.number" required />
<button ng-click="deleteNumber($index)">Delete Number</button>
</div>
<button ng-click="addNumber()">Add Number</button>
<input type="submit" ng-disabled="form.$invalid" />
</form>
</body>
控制器:
app.controller('MainCtrl', function ( $scope ) {
$scope.phoneNumbers = [{
number: '212-123-4567'
}];
$scope.addNumber = function () {
$scope.phoneNumbers.push({
number: ''
});
};
$scope.deleteNumber = function ( index ) {
$scope.phoneNumbers.splice(index, 1);
};
});
这是 Plunkr:工作示例。
我认为代码非常简单:ng-repeat
显示每个电话号码,您可以编辑/删除。如果添加了电话号码,则不能为空;如果电话号码为空,则提交按钮将被禁用。
当提交按钮放在ng-repeat
. 如果您添加电话号码,将其留空,然后将其删除,则提交按钮将保持禁用状态:
<body ng-controller="MainCtrl">
<form name="form">
<input type="submit" ng-disabled="form.$invalid" />
<div ng-repeat="phone in phoneNumbers">
<input ng-model="phone.number" required />
<button ng-click="deleteNumber($index)">Delete Number</button>
</div>
<button ng-click="addNumber()">Add Number</button>
</form>
</body>
这是 plunkr:破碎的例子。
我喜欢 AngularJS,但这几乎把我逼疯了。我花了超过 20 个小时来追逐这个愚蠢的错误。由于通常的演示底部有提交按钮,因此我无法重现该问题。我不得不拿我的实际代码,慢慢地将代码减少到最低限度。这是一个非常庞大而复杂的应用程序,而且...好吧,我现在停止抱怨。
我的问题有两个:
这是一个错误吗?我什至用不稳定的分支(1.1.3)尝试了这个,它的工作方式完全相同。
在不更改 source order的情况下,我能做些什么来解决它。我知道我可以通过 CSS 来移动我的提交按钮,但在我的情况下,这并不是一个真正的选择;我需要提交按钮成为表单中的第一件事。
PS这是它的实际操作视频。