AngularJS与后端php的数据交互方法_第1页
AngularJS与后端php的数据交互方法_第2页
AngularJS与后端php的数据交互方法_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第AngularJS与后端php的数据交互方法简述:

AngularJS诞生于2009年,由MiskoHevery等人创建,后为Google所收购。是一款优秀的前端JS框架,已经被用于Google的多款产品当中。AngularJS有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等等。

它不仅仅是一个类库,而是提供了一个完整的框架。它避免了您和多个类库交互,需要熟悉多套接口的繁琐工作。它由GoogleChrome的开发人员设计,引领着下一代Web应用开发。也许我们5年或10年后不会使用AngularJS,但是它的设计精髓将会一直被沿用。

问题及方案:

既然是前端框架,就免不了与后台的数据交互。本文讲解与PHP数据交互中的重点。

AngularJS的$http不管你使用的是POST还是PUT,默认的发送和请求数据格式都是json的,这个我们可以从它发送的http请求头中看到:Content-Type:application/json;charset=UTF-8。而PHP的GET或者POST接收的http请求数据却是:Content-Type:application/x-www-form-urlencoded;charset=UTF-8。

所以新手在使用AngularJS时候都会遇到这个问题,明明发送过来了,为什么我收不到数据?解决这个问题我们可以从两个方面入手:

一、在PHP中

$data=file_get_contents("php://input");

echo$data;

这样你会发现。$data是一个json数据,之后PHP中你便可以对这个数据做其他处理了。

二、Angular中重构http请求

varws=angular.module("app",[function($httpProvider){

$httpProvider.defaults.headers.post["Content-Type"]="application/x-www-form-urlencoded;charset=utf-8";

$httpProvider.defaults.headers.put['Content-Type']='application/x-www-form-urlencoded;charset=utf-8';

varparam=function(obj){

varquery="",name,value,fullSubName,subName,subValue,innerObj,i;

for(nameinobj){

value=obj[name];

if(valueinstanceofArray){

for(i=0;ivalue.length;++i){

subValue=value[i];

fullSubName=name+"["+i+"]";

innerObj={};

innerObj[fullSubName]=subValue;

query+=param(innerObj)+"

}elseif(valueinstanceofObject){

for(subNameinvalue){

subValue=value[subName];

fullSubName=name+"["+subName+"]";

innerObj={};

innerObj[fullSubName]=subValue;

query+=param(innerObj)+"

}elseif(value!==undefinedvalue!==null){

query+=encodeURIComponent(name)+"="+encodeURIComponent(value)+"

returnquery.lengthquery.substr(0,query.length-1):query;

$httpProvider.defaults.transformRequest=[function(data){

returnangular.isObject(data)String(data)!=="[objectFile]"param(data):data;

}]);

在构建app时直接重写$h

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论