首页 > AngularJS中的$http能否整个表单一起提交?

AngularJS中的$http能否整个表单一起提交?

本人更改公司一个项目,将JQuery中的$.ajax更改成AngularJS中的$http,原来提交数据的时候是$("#form").serialize(),而现在提交数据需要将数据一个个列出来封装成json提交,这里就是想问,angularjs中有没有方法可以向前者一样,一次性将全部的表单数据提交。(PS:公司要求项目中不要再用JQuery)


为form元素指定name属性,然后form会在其所在的scope里按这个名字定义一个form controller。

比方说

<form name="myForm">
  <input name="myInput">
</form>

然后用如下操作取出值

function getFormValue(formCtrl) {
  return Object
    .keys(formCtrl)
    .filter(function(key) {
      return key[0] != '$';
    }
    .reduce(function(res, key) {
      res[key] = formCtrl[key].$modelValue;
      return res;
    }, {});
}

getFormValue($scope.myForm);
// output: {myInput: "..."}

<input ng-model="user.name">
<input ng-model="user.age">

通过上面的方式命名ng-modelcontroller中直接使用$scope.user获取对象。

【热门文章】
【热门文章】