提交按钮未被调用 - AngularJs

时间:2017-01-03 11:05:16

标签: angularjs

我有一个包含多个控件的表单,我在其中设置了必需的字段验证。如果数据正确,我想调用提交按钮。但即使填写了所有数据,并单击“提交”按钮,也不会调用该按钮。以下是使用的示例代码:

  <form name="mainForm" id="createForm" ng-submit="mainForm.$valid && add()" novalidate>
<div ng-controller="testController" ng-init="init()">

  <div class="container" ng-show="createMenu">
                <br />
                <div class="row">
                    <div>
                        <label>Test:</label>
                    </div>
                    <div >
                        <select name="testTypeSelect" required ng-model="selectedtestType" ng-options="test.TestTypeName for test in tests" ng-change="updateImageUrl(selectedTestType)">
                            <option value="">-- Select the test --</option>
                        </select>
                    </div>
                </div>
                <span style="color:red" ng-show="submitted == true && mainForm.testTypeSelect.$error.required"> Type is required</span>

                <div class="row">
                    <div >
                        <label>Name :</label>
                    </div>
                    <div>
                        <input type="text" required ng-model="testName" name="testName" />
                    </div>
                </div>

 <input type="submit" value="Submit" ng-click="submitted=true" /> 

//在controller.js中

 $scope.add = function () {

        $scope.init();   

        alert("hi");
            $scope.addData();

    };

如何解决这个问题? 感谢

1 个答案:

答案 0 :(得分:0)

你的控制器是在form标签之后注入,add()函数调用是在控制器注入之外。

<form name="mainForm" id="createForm" ng-submit="mainForm.$valid && add()" novalidate>
<div ng-controller="testController" ng-init="init()">

更改为

<div ng-controller="testController" ng-init="init()">
<form name="mainForm" id="createForm" ng-submit="mainForm.$valid && add()" novalidate>