這篇文章主要講解了“AngularJS與后端php的數(shù)據(jù)怎么交互”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“AngularJS與后端php的數(shù)據(jù)怎么交互”吧!
金川ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!簡(jiǎn)述:
AngularJS誕生于2009年,由Misko Hevery 等人創(chuàng)建,后為Google所收購(gòu)。是一款優(yōu)秀的前端JS框架,已經(jīng)被用于Google的多款產(chǎn)品當(dāng)中。AngularJS有著諸多特性,最為核心的是:MVC、模塊化、自動(dòng)化雙向數(shù)據(jù)綁定、語(yǔ)義化標(biāo)簽、依賴注入等等。
它不僅僅是一個(gè)類庫(kù),而是提供了一個(gè)完整的框架。它避免了您和多個(gè)類庫(kù)交互,需要熟悉多套接口的繁瑣工作。它由Google Chrome的開發(fā)人員設(shè)計(jì),引領(lǐng)著下一代Web應(yīng)用開發(fā)。也許我們5年或10年后不會(huì)使用AngularJS,但是它的設(shè)計(jì)精髓將會(huì)一直被沿用。
問題及方案:
既然是前端框架,就免不了與后臺(tái)的數(shù)據(jù)交互。本文講解與PHP數(shù)據(jù)交互中的重點(diǎn)。
AngularJS的$http不管你使用的是POST還是PUT,默認(rèn)的發(fā)送和請(qǐng)求數(shù)據(jù)格式都是json的,這個(gè)我們可以從它發(fā)送的http請(qǐng)求頭中看到:Content-Type:application/json;charset=UTF-8。而PHP的GET或者POST接收的http請(qǐng)求數(shù)據(jù)卻是:Content-Type:application/x-www-form-urlencoded;charset=UTF-8。
所以新手在使用AngularJS時(shí)候都會(huì)遇到這個(gè)問題,明明發(fā)送過來了,為什么我收不到數(shù)據(jù)?解決這個(gè)問題我們可以從兩個(gè)方面入手:
一、在PHP中
這樣你會(huì)發(fā)現(xiàn)。$data是一個(gè)json數(shù)據(jù),之后PHP中你便可以對(duì)這個(gè)數(shù)據(jù)做其他處理了。
二、Angular中重構(gòu)http請(qǐng)求
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時(shí)直接重寫$http,將其轉(zhuǎn)化為我們常用的請(qǐng)求方式。這樣之后就像普通的ajax請(qǐng)求一般了。
感謝各位的閱讀,以上就是“AngularJS與后端php的數(shù)據(jù)怎么交互”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)AngularJS與后端php的數(shù)據(jù)怎么交互這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)頁(yè)名稱:AngularJS與后端php的數(shù)據(jù)怎么交互-創(chuàng)新互聯(lián)
文章路徑:http://weahome.cn/article/dojghs.html