Angular學(xué)習(xí)第九天

$http 服務(wù)是什么夕冲?

$http 就是JQuery中的$.ajax

如何用衣迷?

請(qǐng)求一個(gè)已存在的json文件

news.json

{
    "status": "1",
    "message": "成功",
    "data": [
        {
            "id": "556",
            "title": "left_top秘密任務(wù)",
            "image": "/resources/news/1479110226.png",
            "content": "",
            "url": "/challenge",
            "desc": "",
            "created_at": "2016-06-27 11:25:29"
        }, {
            "id": "555",
            "title": "right_top曬勛章",
            "image": "/resources/news/1476350699.png",
            "content": "",
            "url": "/medal",
            "desc": "",
            "created_at": "2016-06-27 11:23:56"
        }, {
            "id": "554",
            "title": "left_bottom邀請(qǐng)有禮",
            "image": "/resources/news/1476181116.png",
            "content": "",
            "url": "/invest_timeline",
            "desc": "",
            "created_at": "2016-05-17 17:40:05"
        }, {
            "id": "496",
            "title": "right_bottom新手教程",
            "image": "/resources/news/1476181156.png",
            "content": "",
            "url": "http://mp.weixin.qq.com/s?__biz=MzA5ODI4MjM1NA==&mid=2649936983&idx=2&sn=ebdaaa65f2216ff223973d25329339f5",
            "desc": "",
            "created_at": "2016-03-17 10:33:01"
        }
    ]
}

controller

//初始我們定義一個(gè) $scope.news 請(qǐng)求成功之后我們給這個(gè)變量重新賦值
appH5.controller("myTabCtrl",['$scope','$http',function($scope,$http){
  $scope.news=[];
  $http.get("mock/news.json")
  .success(function(res){
    console.log(res);
    if(res.status==1){
      $scope.news=res.data;
    }else{
      alert(res.message);
    }
  }).error(function(){
    console.log("error");
  }).then(function(data){
    console.log(data);
  });
});
$http服務(wù)會(huì)返回一個(gè) promise作儿;你可以定義success方法說(shuō)明請(qǐng)求成功之后執(zhí)行什么霎槐;同樣你也可以定義error方法說(shuō)明請(qǐng)求成功之后執(zhí)行什么咨堤。
請(qǐng)求get請(qǐng)求的接口
// 請(qǐng)求成功之后我們給 orders 這個(gè)變量重新賦值
appH5.controller("myTabCtrl",['$scope','$http',function($scope,$http){
  $http.get("http://www.mxx.com/test.php?c=orders")
  .success(function(res){
    console.log(res);
    if(res.status==1){
      $scope.orders=res.data;
    }else{
      alert(res.message);
    }
  }).error(function(){
    console.log("error");
  });
});
請(qǐng)求post請(qǐng)求的接口
// 請(qǐng)求成功之后我們給 orders 這個(gè)變量賦值
appH5.controller("myTabCtrl",['$scope','$http',function($scope,$http){
  $http({
    method:'post',
    url:'http://www.mxx.com/test.php?c=login',
    data:$.param({name:"aaa",id:1,age:20}),
    headers:{'Content-Type': 'application/x-www-form-urlencoded'}
  }).success(function(req){
    console.log(res);
    if(res.status==1){
      $scope.orders=res.data;
    }else{
      alert(res.message);
    }
  })
});
  • $.param方法是jQuery的序列化方法埂伦,post的用法需要借助這個(gè)類(lèi)庫(kù)仔蝌;并且需要設(shè)置headers:{'Content-Type': 'application/x-www-form-urlencoded'}

用$http發(fā)送get請(qǐng)求

appH5.controller("myTabCtrl",['$scope','$http',function($scope,$http){
  $http({
    method: 'GET',
    url: 'http://www.mxx.com/test.php',
    params: { c: 'orders' },//params作為url的參數(shù)
  }).success(function(req){
  console.log(req);
  });
});

//最后請(qǐng)求的url實(shí)際上是 
//http://www.mxx.com/test.php?c=orders泛领;
//params定義的參數(shù)會(huì)被拼接在url后面

$http發(fā)送POST請(qǐng)求

appH5.controller("myTabCtrl",['$scope','$http',function($scope,$http){
  $http({
    method:'post',
    url:'http://www.mxx.com/test.php?c=login',
    data:$.param({name:"aaa",id:1,age:20}),
    headers:{'Content-Type': 'application/x-www-form-urlencoded'}
  }).success(function(req){
  console.log(req);
  });
});

如果你需要在請(qǐng)求完成得到返回?cái)?shù)據(jù)之后執(zhí)行某段操作的話,你可以用 then()方法讓代碼順序執(zhí)行

appH5.controller("myTabCtrl",['$scope','$http',function($scope,$http){
  $http({
    method:'post',
    url:'http://www.mxx.com/test.php?c=login',
    data:$.param({name:"aaa",id:1,age:20}),
    headers:{'Content-Type': 'application/x-www-form-urlencoded'}
  }).success(function(req){
  console.log(req);
  }).then(function(res){
    console.log("我是得到返回?cái)?shù)據(jù)之后才會(huì)執(zhí)行的操作");
  });
});
  • 為什么post請(qǐng)求我要用 $.param敛惊?

我們來(lái)看一下我們不用$.param把data序列化渊鞋,我們?cè)谡{(diào)試工具中看到的傳遞到后臺(tái)的參數(shù)

2180072-a84b93de0f80bdbc.png

當(dāng)我們使用 jQuery的 ajax 方法,我們看到的參數(shù)是

2180072-901cbeca165d8aed.png

jQuery的 ajax 方法

  • 解釋 看起來(lái)執(zhí)行請(qǐng)求的代碼是一樣的瞧挤,但是實(shí)際發(fā)送的時(shí)候明顯后者是鍵值對(duì)的方式锡宋,前者則不是;為什么會(huì)出現(xiàn)這種問(wèn)題呢特恬?因?yàn)閖Query在發(fā)送 data里面的數(shù)據(jù)之前會(huì)進(jìn)行數(shù)據(jù)的序列化(Content-Type:application/x-www-form-urlencoded)如
var data= {name:"aaa",id:1,age:20};
// jQuery在post數(shù)據(jù)之前會(huì)把data轉(zhuǎn)換成字符串:"name=aaa&id=1&age=20"

相反的 Angular不會(huì)執(zhí)行這一操作执俩,它,默認(rèn)傳遞的json字符串(Content-Type: application/json;)癌刽,后端在取前端傳遞的參數(shù)時(shí)不能用 $_REQUEST/$_POST(本人只會(huì)PHP役首,這里以php為例),而必須用

$params = json_decode(file_get_contents('php://input'),true);

這種方式來(lái)獲取前端的參數(shù)显拜。這就意味著你一旦你之前用jQuery寫(xiě)的項(xiàng)目要用Angular重構(gòu)衡奥,那么后端的接口就必須一個(gè)一個(gè)更改獲取參數(shù)的方式;

  • 如果不用后端改讼油,有沒(méi)有解決方案杰赛?
  • 方案1,其實(shí)我已經(jīng)寫(xiě)出來(lái)了矮台,就是用$.param函數(shù)來(lái)序列化之后再賦值給$http 的data屬性乏屯,不過(guò)你得為了這個(gè)引入jQuery這個(gè)類(lèi)庫(kù)。(當(dāng)然如果你想寫(xiě)的話瘦赫,你自己可以寫(xiě)一個(gè)序列化函數(shù))

$http({
  method:'post',
  url:'http://www.mxx.com/test.php?c=login',
  data:$.param({name:"aaa",id:1,age:20}),
  headers:{'Content-Type': 'application/x-www-form-urlencoded'}
}).success(function(req){
console.log(req);
})
  • 方案2 修改Angular的$httpProvider的默認(rèn)配置辰晕,這是最初我進(jìn)我們公司之后用的方法
angular.module('MyModule', [], function($httpProvider) {
// 設(shè)置 Content-Type
$httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8';

/**
 * 序列化data
 * @param {Object} obj
 * @return {String}
 */ 
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;
};

// 重寫(xiě) $http 服務(wù)的 transformRequest 方法對(duì)用戶傳遞過(guò)來(lái)的數(shù)據(jù)進(jìn)行序列化處理
$httpProvider.defaults.transformRequest = [function(data) {
  return angular.isObject(data) && String(data) !== '[object File]' ? param(data) : data;
}];
});

注 這只是簡(jiǎn)單用法,細(xì)節(jié)我會(huì)稍后編輯确虱,比如為什么post必須用$.param含友;和設(shè)置 header

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子窘问,更是在濱河造成了極大的恐慌辆童,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件惠赫,死亡現(xiàn)場(chǎng)離奇詭異把鉴,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)儿咱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)庭砍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人混埠,你說(shuō)我怎么就攤上這事怠缸。” “怎么了钳宪?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵揭北,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我吏颖,道長(zhǎng)罐呼,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任侦高,我火速辦了婚禮嫉柴,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘奉呛。我一直安慰自己计螺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布瞧壮。 她就那樣靜靜地躺著登馒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪咆槽。 梳的紋絲不亂的頭發(fā)上陈轿,一...
    開(kāi)封第一講書(shū)人閱讀 51,258評(píng)論 1 300
  • 那天,我揣著相機(jī)與錄音秦忿,去河邊找鬼麦射。 笑死,一個(gè)胖子當(dāng)著我的面吹牛灯谣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播胎许,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼峻呛,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼罗售!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起钩述,我...
    開(kāi)封第一講書(shū)人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤寨躁,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后牙勘,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體朽缎,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年谜悟,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片北秽。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡葡幸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出贺氓,到底是詐尸還是另有隱情蔚叨,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布辙培,位于F島的核電站蔑水,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏扬蕊。R本人自食惡果不足惜搀别,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望尾抑。 院中可真熱鬧歇父,春花似錦、人聲如沸再愈。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)翎冲。三九已至垂睬,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間抗悍,已是汗流浹背驹饺。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缴渊,地道東北人逻淌。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像疟暖,于是被迫代替她去往敵國(guó)和親卡儒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子田柔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容