AngularJs的POST

由于Angular的POST请求文件类型为application/json,但是大多数服务器接受的请求类型为application/x-www-form-urlencoded(a=xxx&b=xxx)格式。所以很多情况下,我们并不能得到我们想要的结果,必须得改变POST来达到我们的目的。

1.修改POST

$http({

url:url,

        method:'POST',

data:{

a:$scope.a,

b:$scope.b

},

header:{'Content-Type','application/x-www-form-urlcoded'},

transformRequset:fucntion(obj){ //obj是要传到后台的data

let arr=[];

for(name in obj){

arr.push(`${encodeURIComponent(name)}=${encodeURIComponent(obj[name])}`); //将不适合URL传输的字符转为适合的

}

return arr.join("&");

}

});

2.配置模块

mod. config ( function ( $scope , $httpProvider ){
$httpProvider.defaults. transformRequest = function ( obj ){
var arr = [];
for (name in obj){
arr. push ( `${ encodeURIComponent(name)}=${encodeURIComponent(obj[name])} ` );
}
return arr. join ( "&" );
};
$httpProvider.defaults.headers.post[ 'Content-Type' ] = 'application/x-www-form-urlencoded' ;
})

为了方便以后使用,最好是自己封装一个POST模块,这样以后在使用时,只需引入即可。

let commonMod =angular.module =( "common",[]);
commonMod. config( function( $httpProvider){
$httpProvider.defaults. transformRequest = function( obj){
let arr =[];
for(name in obj){
arr. push( `${ encodeURIComponent (name) }=${ encodeURIComponent ( obj[name]) }`);
}
return arr. join( "&");
};
$httpProvider.defaults.header.post[ 'Content-Type'] = 'application/x-www-form-urlencoded';
});
将上面代码单独保存为一个JS文件,在引入Angular.js后引入该文件,然后只需在要使用的模块(module)添加对common的依赖即可。

















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值