浅谈angularjs $http提交数据探索
发布时间 - 2026-01-10 22:40:26 点击率:次前两天在搞自己的项目,前端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使用的简单介绍
# 的是
# 自己的
# 都是
# 小伙伴
# 他们的
# 给我
# 这个问题
# 我用
# 采用了
# 有兴趣
# 解决问题
# 可以看出
# 如图
# 事了
# 首页
# 试了
# 前两天
# 服务端
# 大家多多
# 不同之处
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
Laravel如何实现用户密码重置功能?(完整流程代码)
如何在阿里云购买域名并搭建网站?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
原生JS实现图片轮播切换效果
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
php json中文编码为null的解决办法
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
如何快速搭建二级域名独立网站?
Laravel如何使用Livewire构建动态组件?(入门代码)
nodejs redis 发布订阅机制封装实现方法及实例代码
Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程
如何快速生成橙子建站落地页链接?
如何快速搭建虚拟主机网站?新手必看指南
Laravel怎么判断请求类型_Laravel Request isMethod用法
LinuxShell函数封装方法_脚本复用设计思路【教程】
Laravel如何使用withoutEvents方法临时禁用模型事件
Mybatis 中的insertOrUpdate操作
Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】
微信小程序 canvas开发实例及注意事项
小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何正确下载安装西数主机建站助手?
如何在IIS中新建站点并解决端口绑定冲突?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程
Laravel如何创建自定义中间件?(Middleware代码示例)
JS经典正则表达式笔试题汇总
如何自定义建站之星网站的导航菜单样式?
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Laravel如何使用Vite进行前端资源打包?(配置示例)
打开php文件提示内存不足_怎么调整php内存限制【解决方案】
UC浏览器如何设置启动页 UC浏览器启动页设置方法
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
Laravel的.env文件有什么用_Laravel环境变量配置与管理详解
java ZXing生成二维码及条码实例分享
零服务器AI建站解决方案:快速部署与云端平台低成本实践
如何用已有域名快速搭建网站?
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
html5的keygen标签为什么废弃_替代方案说明【解答】
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
如何用y主机助手快速搭建网站?
制作电商网页,电商供应链怎么做?
Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】

