gpt4 book ai didi

即使不提交,AngularJS ng-submit 事件处理程序也会被调用

转载 作者:行者123 更新时间:2023-12-04 02:50:19 24 4
gpt4 key购买 nike

我正在尝试使用 angular-ui 设置表单验证。我想在提交之前检查表单是否有效,所以我设置了一个 ng-submit 事件处理程序。

但在实现任何验证之前,我注意到即使不提交表单,事件处理程序也会被调用。在下面的示例中,当我单击“添加项目”按钮时,它会被调用:

<div ng-app="app">
<div ng-controller="ctrl">
<form name="myForm" ng-submit="sub()" novalidate>
<div ng-repeat="item in items">
<ng-form name="row">
<input type="text" name="value" ng-model="item.value" required />
</ng-form>
</div>
<button ng-click="addItem()">Add Item</button>
<input type="submit" value="Submit"/>
</form>
</div>
</div>

和JS:
 var app = angular.module('app', ['ng']);

app.controller('ctrl', ['$scope', function($scope) {
$scope.items = [];
$scope.addItem = function() {
$scope.items.push({ value: $scope.items.length });
};

$scope.sub = function() {
alert("submitted?");
};
}]);

在这里查看我的 fiddle :

http://jsfiddle.net/UvLBj/2/

这是应该发生的吗?对我来说,ng-submit 不只是在表单提交时被触发似乎是错误的......我做错了什么吗?

最佳答案

相信您需要添加 type="button"以避免意外调用提交。更新了 fiddle ,似乎修复了它:

http://jsfiddle.net/UvLBj/3/

<button type="button" ng-click="doSomething()">Test</button>

关于即使不提交,AngularJS ng-submit 事件处理程序也会被调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21863821/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com