本人更改公司一个项目,将JQuery中的$.ajax更改成AngularJS中的$http,原来提交数据的时候是$("#form").serialize(),而现在提交数据需要将数据一个个列出来封装成json提交,这里就是想问,angularjs中有没有方法可以向前者一样,一次性将全部的表单数据提交。(PS:公司要求项目中不要再用JQuery)
滿天的星座2017-05-15 17:08:22
<input ng-model="user.name">
<input ng-model="user.age">
通过上面的方式命名ng-model
在controller
中直接使用$scope.user
获取对象。
phpcn_u15822017-05-15 17:08:22
为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: "..."}