Retrieve all inputs values from a form AngularJS

后端 未结 1 907
我寻月下人不归
我寻月下人不归 2021-01-20 05:45

I have a massive form with more or less 80 / 90 inputs.

My main problem is How can I pass all those inputs belonging to unique form in an ajax requ

1条回答
  •  醉话见心
    2021-01-20 06:45

    Indeed, as Michal's comment suggested, it doesn't look like you are using ng-model.

    Angular's jqLite doesn't support serialize() since with Angular one would typically build a ViewModel that would then be bound to a form.

    But, if you are out of luck, you could add jQuery.js to get the serialize() support and create a simple directive - serializer - that would act on a form.

    app.directive("serializer", function(){
      return {
        restrict: "A",
        scope: {
          onSubmit: "&serializer"
        },
        link: function(scope, element){
          // assuming for brevity that directive is defined on 
    var form = element; form.submit(function(event){ event.preventDefault(); var serializedData = form.serialize(); scope.onSubmit({data: serializedData}); }); } }; });

    And use it as follows:

    
      
      
      
    
    

    And in the controller:

    $scope.submit = function(data){
       console.log(data);
    }
    

    plunker

    EDIT:

    If you are using ng-model and in fact have a proper ViewModel, then this is the "Angular way" and so, you should have some object that is bound to the form inputs - you should just submit that.

    ...
    $scope.fooObject = {}; $scope.onSubmit = function(){ $http.post("url/to/server", {data: $scope.fooObject}) .success(...); }

    0 讨论(0)
提交回复
热议问题