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

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

阅读 3.2k
2 个回答
<input ng-model="user.name">
<input ng-model="user.age">

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

为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: "..."}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进