繁体   English   中英

控制器中的AngularJS形式始终未定义

[英]Angularjs form in controller always undefined

在我的项目中,我使用ui-view并具有以下结构(删除了不必要的代码):

<main class="content">
    <div class="inner" ng-controller="OrderPageController">
        <div ui-view="main-info"></div>
        <div ui-view="comments"></div>
        <div ui-view="bids-list"></div>
        <div ui-view="add-bid"></div>
    </div>
</main>

在加价竞标视图中:

<form name="newbidform" novalidate ng-submit="postNewBid(newbidform);">
   <input type="text" ng-model="newbid.bid" required>
   <input type="submit">
</form>

因此,然后我提交表单,尝试检查所有必需的输入是否有效:

$scope.postNewBid = function(form) {

console.log(form) // $valid and $invalid always undefined
console.log($scope.newbidform) // always undefined

        // check validity before send
        if (!form.$valid) {
            angular.forEach(form.$error, function (field) {
                angular.forEach(field, function(errorField){
                    errorField.$setTouched();
                })
            });
            $scope.failedSubmit = true;
            return false;
        } else {
            $scope.failedSubmit = false;
        } 
// other things if form is valid

因此,表单的问题始终是不确定的(根本就是$ valid / $ invalid attr)。 我试图将formName用作函数中的参数,用作$ scope.formName变量(始终未定义),并在窗体上第二次定义了两次控制器:

<form name="newbidform" novalidate ng-submit="postNewBid();" ng-controller="OrderPageController">

实际上,它可以工作,但是当我尝试访问控制器中的其他变量时,我做不到。 那么,有没有办法在AngularJs的控制器中获取表单状态? 谢谢

newbid是您想要获取的变量,对吗?

尝试:

<form name="newbidform" novalidate ng-submit="postNewBid(newbid);">

听起来您的表单嵌套在子范围内,例如在ng-includeng-if在这种情况下,因为在父范围内不存在表单对象,所以当angular在子范围内创建父对象时,父对象将看不到。

您可以通过在父控制器中简单创建一个空对象来解决该问题,该对象将被子作用域继承。 由于该对象现在存在,因此将不需要创建新对象,并且所有属性都将添加到子作用域中的引用。

$scope.newbidform ={};
$scope.postNewBid = function(form) {...

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM