国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

AngularJS與后端php的數據交互方法

2019-11-19 13:16:51
字體:
來源:轉載
供稿:網友

簡述:

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的數據交互方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁陵县| 定州市| 镇赉县| 都昌县| 随州市| 安徽省| 德格县| 旅游| 五家渠市| 泰和县| 耒阳市| 电白县| 崇仁县| 昔阳县| 苏尼特右旗| 阿城市| 客服| 新泰市| 临汾市| 云南省| 聂荣县| 长海县| 光泽县| 浪卡子县| 兴国县| 兴化市| 寿阳县| 新巴尔虎左旗| 乐亭县| 额尔古纳市| 东乡族自治县| 棋牌| 峨山| 洱源县| 方城县| 西青区| 乐业县| 牙克石市| 六盘水市| 上杭县| 成武县|