2016-09-22 5 views
0

나는 angularjs가 비교적 새로운 편입니다.
양식 제출을 시도 할 때 제출이 트리거되지 않습니다. 또한 나는 $ scope.user에 액세스 할 수 없으므로 서버에 게시 할 수 없습니다. 나는 틀린 것이 틀림 없다!제출이 트리거되지 않음

<div ng-controller="contactController"> 
       <form name="myForm" class="form-horizontal" role="form" ng-submit="submit()"> 
        <div class="form-group"> 
         <label for="company" class="col-md-4 control-label">Company Name</label> 
         <div class="col-md-4"> 
          <input type="text" class="form-control" id="company" placeholder="Company Name" ng-model="user.company" required> </div> 
        </div> 
        <div class="form-group"> 
         <label for="firstName" class="col-md-4 control-label">First Name</label> 
         <div class="col-md-4"> 
          <input type="text" class="form-control" id="firstName" placeholder="First Name" ng-model="user.firstname" required> </div> 
        </div> 
        <div class="form-group"> 
         <label for="lastName" class="col-md-4 control-label">Last Name</label> 
         <div class="col-md-4"> 
          <input type="text" class="form-control" id="lastName" placeholder="Last Name" ng-model="user.lastname" required> </div> 
        </div> 
        <div class="form-group" ng-class="{'has-error': myForm.phone.$error.number}"> 
         <label for="tel" class="col-md-4 control-label">Phone Number</label> 
         <div class="col-md-4"> 
          <input type="number" class="form-control" id="phone" placeholder="Phone Number" ng-minlength="10" ng-maxlength="10" ng-model="user.phone" ng-required="true" name="phone"> <span class="help-block" ng-show="myForm.phone.$error.required || 
           myForm.phone.$error.number"> 
           Valid phone number is required 
       </span> <span class="help-block" ng-show="((myForm.phone.$error.minlength || 
           myForm.phone.$error.maxlength) && 
           myForm.phone.$dirty) "> 
           phone number should be 10 digits 
       </span> </div> 
        </div> 
        <div class="form-group"> 
         <label for="email" class="col-md-4 control-label">Email</label> 
         <div class="col-md-4"> 
          <input type="email" class="form-control" id="email" placeholder="Email" ng-model="user.email" name="input" required> <span class="error" ng-show="myForm.input.$error.required"> 
           Required!</span> <span class="error" ng-show="myForm.input.$error.email"> 
           Not valid email!</span> </div> 
        </div> 
        <div class="form-group"> 
         <label for="comments" class="col-md-4 control-label">Comments</label> 
         <div class="col-md-4"> 
          <textarea id="text" class="form-control" placeholder="Comments" cols=10 ng-model="user.comments"></textarea> 
         </div> 
        </div> 
        <!--<div class="form-group"> 
        <div class="g-recaptcha pull-right" data-sitekey=""></div></div>--> 
        <div class="form-group"> 
         <div class="col-md-4"> 
          <button type="submit" class="btn btn-success" ng-click="reset()">Submit</button> 
         </div> 
        </div> 
       </form> 
      </div> 

는 내 컨트롤러 :

myApp.controller('contactController', ['$scope', '$http', function ($scope, $http) { 
    //$.getScript("https://www.google.com/recaptcha/api.js"); 
    var user = { 
     "company": "" 
     , "firstname": "" 
     , "lastname": "" 
     , "phone": "" 
     , "email": "" 
     , "comments": "" 
    }; 
    $scope.submit = function() { 
     console.log($scope.user); 
     $http({ 
      method: 'POST' 
      , url: '/contactUs' 
      , data: $scope.user, //forms user object 
      headers: { 
       'Content-Type': 'application/x-www-form-urlencoded' 
      } 
     }).success(function (data) { 
      console.log('Got a response'); 
      $scope.reset; 
     }).error(function (data) { 
      console.log("error detected"); 
     }); 
    } 
    $scope.reset = function() { 
     $scope.user = angular.copy(user); 
     $scope.myForm.$setPristine(); 
     $scope.myForm.$setUntouched(); 
    } 
}]); 

답변

0

A) 귀하의 $scope.reset 함수가 먼저 호출지고 있습니다.

B) 재설정 기능은 $scope.useruser 사본으로 설정합니다. 이는 비어 있습니다.

이것이 작동하지 않는 이유입니다. 당신은 제출할 기회가 있기 전에 $scope.user을 비우고 있습니다. 따라서 $scope.user은 유효하지 않은 양식 데이터로 채워집니다.

제출 버튼에서 바로 클릭을 제거하십시오. 그리고 성공한 경우 $scope.submit$scope.reset으로 실행하십시오. 해당하지만,이 작업을 수행하려고했던 것 같은데 :

$scope.reset; 

이 될 필요가 :

$scope.reset(); 

을 성공 콜백에서.