AngularJS與后端php的數(shù)據(jù)怎么交互

這篇文章主要講解了“AngularJS與后端php的數(shù)據(jù)怎么交互”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“AngularJS與后端php的數(shù)據(jù)怎么交互”吧!

站在用戶的角度思考問題,與客戶深入溝通,找到云州網(wǎng)站設(shè)計與云州網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、申請域名、網(wǎng)絡(luò)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋云州地區(qū)。

簡述:

AngularJS誕生于2009年,由Misko Hevery 等人創(chuàng)建,后為Google所收購。是一款優(yōu)秀的前端JS框架,已經(jīng)被用于Google的多款產(chǎn)品當(dāng)中。AngularJS有著諸多特性,最為核心的是:MVC、模塊化、自動化雙向數(shù)據(jù)綁定、語義化標(biāo)簽、依賴注入等等。

它不僅僅是一個類庫,而是提供了一個完整的框架。它避免了您和多個類庫交互,需要熟悉多套接口的繁瑣工作。它由Google Chrome的開發(fā)人員設(shè)計,引領(lǐng)著下一代Web應(yīng)用開發(fā)。也許我們5年或10年后不會使用AngularJS,但是它的設(shè)計精髓將會一直被沿用。

問題及方案:

既然是前端框架,就免不了與后臺的數(shù)據(jù)交互。本文講解與PHP數(shù)據(jù)交互中的重點。

AngularJS的$http不管你使用的是POST還是PUT,默認(rèn)的發(fā)送和請求數(shù)據(jù)格式都是json的,這個我們可以從它發(fā)送的http請求頭中看到:Content-Type:application/json;charset=UTF-8。而PHP的GET或者POST接收的http請求數(shù)據(jù)卻是:Content-Type:application/x-www-form-urlencoded;charset=UTF-8。

所以新手在使用AngularJS時候都會遇到這個問題,明明發(fā)送過來了,為什么我收不到數(shù)據(jù)?解決這個問題我們可以從兩個方面入手:

一、在PHP中

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

這樣你會發(fā)現(xiàn)。$data是一個json數(shù)據(jù),之后PHP中你便可以對這個數(shù)據(jù)做其他處理了。

二、Angular中重構(gòu)http請求

var ws = 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';
 var param = function (obj) {
 var query = "", name, value, fullSubName, subName, subValue, innerObj, i;
 for (name in obj) {
  value = obj[name];
  if (value instanceof Array) {
  for (i = 0; i < value.length; ++i) {
   subValue = value[i];
   fullSubName = name + "[" + i + "]";
   innerObj = {};
   innerObj[fullSubName] = subValue;
   query += param(innerObj) + "&";
  }
  } else if (value instanceof Object) {
  for (subName in value) {
   subValue = value[subName];
   fullSubName = name + "[" + subName + "]";
   innerObj = {};
   innerObj[fullSubName] = subValue;
   query += param(innerObj) + "&";
  }
  } else if (value !== undefined && value !== null) {
  query += encodeURIComponent(name) + "=" + encodeURIComponent(value) + "&";
  }
 }
 return query.length ? query.substr(0, query.length - 1) : query;
 };
 $httpProvider.defaults.transformRequest = [function (data) {
 return angular.isObject(data) && String(data) !== "[object File]" ? param(data) : data;
 }];
}]);

在構(gòu)建app時直接重寫$http,將其轉(zhuǎn)化為我們常用的請求方式。這樣之后就像普通的ajax請求一般了。

感謝各位的閱讀,以上就是“AngularJS與后端php的數(shù)據(jù)怎么交互”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對AngularJS與后端php的數(shù)據(jù)怎么交互這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

文章題目:AngularJS與后端php的數(shù)據(jù)怎么交互
標(biāo)題來源:http://bm7419.com/article0/gihjio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、電子商務(wù)、營銷型網(wǎng)站建設(shè)、網(wǎng)站策劃全網(wǎng)營銷推廣、Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司