浅谈angularjs $http提交数据探索

前两天在搞自己的项目,前端js框架用的是angularjs框架;网站整的差不多的时候出事了;那就是当我用$http.post()方法向服务器提交一些数据的时候;后台总是接收不到数据;

于是采用了其他方法暂时性替代一下;

今天正好有时间研究这个事情;网上查了很多资料;都试了试;都是不太好;但是还是给我提供了一些解决问题的思路;

正文开始:首先做了个demo如下;主要是为了比较他们的不同之处;

html如下:

rush:xhtml;">
<div class="container">

<div class="row">

<div class="col-md-5">

<p class="h4 text-center"&gt;jQ的$.post()提交</p>



<div class="form-group"&gt;

 <label for="exampleInputEmail1"&gt;<a href="https://www.jb51.cc/tag/yonghuming/" target="_blank" class="keywords">用户名</a></label>

 <input type="text" ng-model="sdata.name" class="form-control" placeholder="<a href="https://www.jb51.cc/tag/yonghuming/" target="_blank" class="keywords">用户名</a>"&gt;

</div>

<div class="form-group"&gt;

 <label for=""&gt;密码</label>

 <input type="password" ng-model="sdata.pwd" class="form-control" placeholder="密码"&gt;

</div>

<button type="button" class="btn btn-primary btn-block" ng-click="<a href="https://www.jb51.cc/tag/jpos/" target="_blank" class="keywords">jpos</a>tData()"&gt;jQ提交</button>

<div class="col-md-2">

<div class="col-md-5">

<p class="h4 text-center"&gt;angularjs的$http.post()<a href="https://www.jb51.cc/tag/gongneng/" target="_blank" class="keywords">功能</a></p>



<div class="form-group"&gt;

 <label for="exampleInputEmail1"&gt;<a href="https://www.jb51.cc/tag/yonghuming/" target="_blank" class="keywords">用户名</a></label>

 <input type="text" ng-model="sdata2.name" class="form-control" placeholder="<a href="https://www.jb51.cc/tag/yonghuming/" target="_blank" class="keywords">用户名</a>"&gt;

</div>

<div class="form-group"&gt;

 <label for=""&gt;密码</label>

 <input type="password" ng-model="sdata2.pwd" class="form-control" placeholder="密码"&gt;

</div>

<button type="button" class="btn btn-primary btn-block" ng-click="aPostData()"&gt;$http提交</button>

js代码如下:

rush:js;"> var app = angular.module('jjd',[]); app.controller('index',function($scope,$http){ $scope.sdata = { name:'jQuery',pwd:'jQuery' }; $scope.sdata2 = { name:'Angularjs',pwd:'Angularjs' };

/jQ的ajax提交/
$scope.jpostData = function(){
//console.log($scope.sdata);
$.post('/web/data.PHP',$scope.sdata,function(d){
console.log(d);
})
};

/angularjs的$http提交/
$scope.aPostData = function(){

$http({
url: '/web/data.PHP',method: 'POST',data:$scope.sdata2
}
}).success(function(da){
console.log(da);
});
};
});

后台采用PHP的$_POST接收:

rush:PHP;"> $msg = array();
$msg['name'] = $aname;
$msg['pwd'] = $apwd;
echo json_encode($msg);
?>

服务器采用wampsever的本地启动的本地服务器。致此,页面服务搭建完毕;开始测试;

结果如图:

从上图的对比中可以看出后台接收不到值得原因主要是1、2、3处不同;

其中1和2是请求的头文件信息;

3是数据类型不同;jq发送的是Form Data;而angularjs认发送的是json数据;

产生原因已经找到;下面开始改造;

首先针对1和2,在$http()的方法中配置header信息;

其次对数据进行转换;这里我做了个简单的json到string转换的服务;

改造后的代码如下:

rush:js;"> /*------创建angularjs应用------*/ var app = angular.module('jjd',[]);

/创建json格式到string的转换服务/
app.service('jsonToStr',function(){
this.transform = function(jsonData){
var string = '';

for(str in jsonData){
string = string + str +'=' + jsonData[str] +'&';
}

var _last = string.lastIndexOf('&');

string = string.substring(0,_last);

return string;
};
});

/---------首页控制器--------/
app.controller('index',$http,jsonToStr){//注入创建的jsonToStr服务
$scope.sdata = {
name:'jQuery',function(d){
console.log(d);
})
};

/angularjs的$http提交/
$scope.aPostData = function(){
//console.log(jsonToStr.transform($scope.sdata2));

$http({
url: '/web/data.PHP',data:$scope.sdata2,data: jsonToStr.transform($scope.sdata2),//对提交的数据格式化
headers: {
'Accept': '/','Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
}
}).success(function(da){
console.log(da);
});
};
});

致此,angularjs提交数据后台接收不到的问题解决(只针对json数据格式);献给奋斗中的小伙伴;

这个问题应该还有一种思路;就是在服务端进行对获取json格式的数据的支持,有兴趣的小伙伴可以尝试一下;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

$httpangularjsangularjs提交数据

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...