首页 > 编程 > JavaScript > 正文

浅谈angularjs $http提交数据探索

2019-11-19 17:51:05
字体:
来源:转载
供稿:网友

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

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

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

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

html如下:

<div class="container-fluid" data-ng-app="jjd" data-ng-controller="index"> <div class="container">  <div class="row">       <div class="col-md-5">    <p class="h4 text-center">jQ的$.post()提交</p>    <p> </p>    <div class="form-group">     <label for="exampleInputEmail1">用户名</label>     <input type="text" ng-model="sdata.name" class="form-control" placeholder="用户名">    </div>    <div class="form-group">     <label for="">密码</label>     <input type="password" ng-model="sdata.pwd" class="form-control" placeholder="密码">    </div>    <button type="button" class="btn btn-primary btn-block" ng-click="jPostData()">jQ提交</button>   </div>   <div class="col-md-2"> </div>   <div class="col-md-5">    <p class="h4 text-center">angularjs的$http.post()功能</p>    <p> </p>    <div class="form-group">     <label for="exampleInputEmail1">用户名</label>     <input type="text" ng-model="sdata2.name" class="form-control" placeholder="用户名">    </div>    <div class="form-group">     <label for="">密码</label>     <input type="password" ng-model="sdata2.pwd" class="form-control" placeholder="密码">    </div>    <button type="button" class="btn btn-primary btn-block" ng-click="aPostData()">$http提交</button>   </div>      </div> </div></div> 

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接收:

<?phpheader("Content-type: text/html; charset=utf-8"); $aname = $_POST['name'];$apwd = $_POST['pwd'];$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转换的服务;

改造后的代码如下:

/*------创建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',function($scope,$http,jsonToStr){//注入创建的jsonToStr服务 $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(){  //console.log(jsonToStr.transform($scope.sdata2));    $http({   url: '/web/data.php',   method: 'POST',   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格式的数据的支持,有兴趣的小伙伴可以尝试一下;

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表