全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

浅谈angularjs $http提交数据探索

前两天在搞自己的项目,前端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接收:

<?php
header("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格式的数据的支持,有兴趣的小伙伴可以尝试一下;

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


# angularjs提交数据  # angularjs  # $http  # 简介AngularJS中$http服务的用法  # 对比分析AngularJS中的$http.post与jQuery.post的区别  # 详解AngularJS中$http缓存以及处理多个$http请求的方法  # 详解AngularJS中的http拦截  # AngularJS中$http服务常用的应用及参数  # 后端接收不到AngularJs中$http.post发送的数据原因分析及解决办法  # AngularJS通过$http和服务器通信详解  # AngularJS出现$http异步后台无法获取请求参数问题的解决方法  # angularJS之$http:与服务器交互示例  # AngularJS中$http使用的简单介绍  # 的是  # 自己的  # 都是  # 小伙伴  # 他们的  # 给我  # 这个问题  # 我用  # 采用了  # 有兴趣  # 解决问题  # 可以看出  # 如图  # 事了  # 首页  # 试了  # 前两天  # 服务端  # 大家多多  # 不同之处 


相关文章: 韩国服务器如何优化跨境访问实现高效连接?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  寿县云建站:智能SEO优化与多行业模板快速上线指南  建站主机无法访问?如何排查域名与服务器问题  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何彻底卸载建站之星软件?  青浦网站制作公司有哪些,苹果官网发货地是哪里?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  北京专业网站制作设计师招聘,北京白云观官方网站?  建站主机解析:虚拟主机配置与服务器选择指南  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何在建站之星网店版论坛获取技术支持?  三星网站视频制作教程下载,三星w23网页如何全屏?  如何用y主机助手快速搭建网站?  专业网站建设制作报价,网页设计制作要考什么证?  临沂网站制作企业,临沂第三中学官方网站?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  如何在阿里云域名上完成建站全流程?  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  如何快速搭建支持数据库操作的智能建站平台?  如何撰写建站申请书?关键要点有哪些?  Python路径拼接规范_跨平台处理说明【指导】  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  名字制作网站免费,所有小说网站的名字?  建站之星如何快速解决建站难题?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  制作表格网站有哪些,线上表格怎么弄?  高端建站三要素:定制模板、企业官网与响应式设计优化  nginx修改上传文件大小限制的方法  如何用西部建站助手快速创建专业网站?  如何选择最佳自助建站系统?快速指南解析优劣  如何续费美橙建站之星域名及服务?  小建面朝正北,A点实际方位是否存在偏差?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  如何通过服务器快速搭建网站?完整步骤解析  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  如何选择适配移动端的WAP自助建站平台?  如何通过多用户协作模板快速搭建高效企业网站?  如何用腾讯建站主机快速创建免费网站?  ,交易猫的商品怎么发布到网站上去?  商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?  已有域名如何免费搭建网站?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  如何用PHP快速搭建CMS系统?  网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?  MySQL查询结果复制到新表的方法(更新、插入)  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。