91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

AngularJS與后端php的數據怎么交互

發布時間:2021-08-16 10:44:58 來源:億速云 閱讀:243 作者:chen 欄目:web開發

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

簡述:

AngularJS誕生于2009年,由Misko Hevery 等人創建,后為Google所收購。是一款優秀的前端JS框架,已經被用于Google的多款產品當中。AngularJS有著諸多特性,最為核心的是:MVC、模塊化、自動化雙向數據綁定、語義化標簽、依賴注入等等。

它不僅僅是一個類庫,而是提供了一個完整的框架。它避免了您和多個類庫交互,需要熟悉多套接口的繁瑣工作。它由Google Chrome的開發人員設計,引領著下一代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中

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

這樣你會發現。$data是一個json數據,之后PHP中你便可以對這個數據做其他處理了。

二、Angular中重構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;
 }];
}]);

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

感謝各位的閱讀,以上就是“AngularJS與后端php的數據怎么交互”的內容了,經過本文的學習后,相信大家對AngularJS與后端php的數據怎么交互這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

赤峰市| 内乡县| 澜沧| 冷水江市| 视频| 镶黄旗| 宁陵县| 隆子县| 文水县| 梅河口市| 临漳县| 论坛| 苏尼特右旗| 观塘区| 内黄县| 三亚市| 无锡市| 祁连县| 东辽县| 龙陵县| 南川市| 荥经县| 资中县| 游戏| 澳门| 大化| 从化市| 天柱县| 唐山市| 武强县| 册亨县| 柳州市| 出国| 平和县| 海林市| 渑池县| 江西省| 新泰市| 罗田县| 枝江市| 襄垣县|