【问题标题】:Can I trigger a form submit from a controller?我可以从控制器触发表单提交吗?
【发布时间】:2013-04-06 20:37:47
【问题描述】:

我想在控制器中进行传统的表单提交。场景是我想在我的网络服务器上点击一个路由并重定向到它的响应,我可以使用 HTML 中的常规表单来完成,但我还想在按下提交按钮时对其字段进行一些验证,并且如果验证失败,我不想做路由。

我知道 ng-valid,但我只希望在按下按钮时进行验证。

有没有办法从控制器内有条件地提交表单?

【问题讨论】:

    标签: forms angularjs submit


    【解决方案1】:
    $scope.payForm.$setSubmitted();
    

    将表单设置为 $submitted 状态。这还将在表单的所有子表单和父表单上设置 $submitted

    https://docs.angularjs.org/api/ng/type/form.FormController#$setSubmitted

    【讨论】:

      【解决方案2】:

      从@ReklatsMasters 的回答展开,如果您想在提交表单之前更改值,您可以这样做...

      <form ng-form-commit action="/" name='payForm' method="post" target="_top">
          <input type="hidden" id="currency_code" name="currency_code" value="USD">
          <button type='button' ng-click='save('GBP', payForm)'>buy</button>
      </form>
      
      .directive("ngFormCommit", [function(){
          return {
              require:"form",
              link: function($scope, $el, $attr, $form) {
                  $form.commit = function($newCurrency) {
                      $el[0].querySelector('#currency_code').value = $newCurrency;
                      $el[0].submit();
                  };
              }
          };
      }])
      
      .controller("AwesomeCtrl", ["$scope", function($scope){
         $scope.save = function($newCurrency, $form) {
           if ($form.$valid) {
               $form.commit($newCurrency);
           }
         };
      }])
      

      【讨论】:

        【解决方案3】:

        这不是 Angular 的方式,但您可以使用 vanilla javascript 提交表单。例如,您可以给表单一个 id 并执行以下操作:

        document.getElementById('myForm').submit()

        或者如果你有提交按钮,你可以点击它:

        document.getElementById('myForm-submit').click()

        我发现第一个没有保留数据绑定(我在一个没有 Angular 替代项的带有 JQuery 小部件的项目中使用它),但第二个保留了绑定。我认为这与 JQuery 小部件的编写方式有关。

        您可以在此处查看有关使用 vanilla JS 触发表单的更多信息:

        How to submit a form using javascript?

        【讨论】:

        • 这不会触发 ng-submit
        【解决方案4】:

        您可以将提交方法添加到 FormController。我这样做了:

        <form ng-form-commit action="/" name='payForm' method="post" target="_top">
            <input type="hidden" name="currency_code" value="USD">
            <button type='button' ng-click='save(payForm)'>buy</button>
        </form>
        
        .directive("ngFormCommit", [function(){
            return {
                require:"form",
                link: function($scope, $el, $attr, $form) {
                    $form.commit = function() {
                        $el[0].submit();
                    };
                }
            };
        }])
        
        .controller("AwesomeCtrl", ["$scope", function($scope){
           $scope.save = function($form) {
             if ($form.$valid) {
                 $form.commit();
             }
           };
        }])
        

        【讨论】:

          【解决方案5】:

          在表单有效之前直接禁用提交按钮怎么样:

          <button type="submit" ng-disabled="form.$invalid">Submit</button>
          

          看看我遇到的类似问题: AngularJS Form Validation with Directives - "myform.$valid" not quite right for me

          【讨论】:

            【解决方案6】:

            您是否尝试在表单上使用 ng-submit 指令?您可以在验证后返回 true/false。

            控制器

            app.controller('MainCtrl', ['$location', function($scope, $location) {
              $scope.submit = function(user) {
                var isvalid = true;
                // validation 
                if (isvalid) {
                    $http.get('api/check_something', {}).then(function(result) {
                        $location.path(result.data);
                    });
                    return true;
                }
                return false; //failed
              }
            });
            

            Html(你不能有动作属性)

            <form name="formuser" ng-submit="submit(user)">
                <input type="text" ng-model="user.firstname" />
                <input type="text" ng-model="user.lastname" />
                <button type="submit">Submit</button>
            </form>
            

            【讨论】:

            • 我有这个想法,但我需要指定一个操作。
            • 这与 OP 的要求相反。这在触发 html 表单提交之前添加了一种“钩子”。 OP 询问如何从角度控制器触发表单提交,而不是如何向已经运行的提交添加挂钩。
            猜你喜欢
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 2015-04-27
            • 2012-09-21
            • 1970-01-01
            • 2011-03-19
            相关资源
            最近更新 更多