乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      AngularJS中$http服務(wù)的簡單用法

       瑤疏影 2017-03-28

      http://www./kf/201506/405137.html

      我們可以使用內(nèi)置的$http服務(wù)直接同外部進行通信。$http服務(wù)只是簡單的封裝了瀏覽器原生的XMLHttpRequest對象。

      1、鏈?zhǔn)秸{(diào)用

      $http服務(wù)是只能接受一個參數(shù)的函數(shù),這個參數(shù)是一個對象,包含了用來生成HTTP請求的
      配置內(nèi)容。這個函數(shù)返回一個promise對象,具有success和error兩個方法。
      $http({
      url:'data.json',
      method:'GET'
      }).success(function(data,header,config,status){
      //響應(yīng)成功

      }).error(function(data,header,config,status){
      //處理響應(yīng)失敗
      });

      2、返回一個promise對象
      var promise=$http({
      method:'GET',
      url:"data.json"
      });

      由于$http方法返回一個promise對象,我們可以在響應(yīng)返回時用then方法來處理回調(diào)。如果
      使用then方法,會得到一個特殊的參數(shù),它代表了相應(yīng)對象的成功或失敗信息,還可以接受兩個
      可選的函數(shù)作為參數(shù)。或者可以使用success和error回調(diào)代替。
      promise.then(function(resp){
      //resp是一個響應(yīng)對象

      },function(resp){
      //帶有錯誤信息的resp

      });

      或者這樣:
      promise.success(function(data,status,config,headers){
      //處理成功的響應(yīng)
      });

      promise.error(function(data,status,hedaers,config){
      //處理失敗后的響應(yīng)
      });

      then()方法與其他兩種方法的主要區(qū)別是,它會接收到完整的響應(yīng)對象,而success()和error()則會對響應(yīng)對
      象進行析構(gòu)。

      3、快捷的get請求

      ①$http.get('/api/users.json');

      get()方法返回HttpPromise對象。

      還可以發(fā)送比如:delete/head/jsonp/post/put 函數(shù)內(nèi)可接受參數(shù)具體參照148頁


      ②以再發(fā)送jsonp請求舉例說明: 為了發(fā)送JSONP請求,其中url必須包含JSON_CALLBACK字樣。

      jsonp(url,config) 其中config是可選的

      var promise=$http.jsonp("/api/users.json?callback=JSON_CALLBACK");


      4、也可以將$http當(dāng)做函數(shù)來使用,這時需要傳入一個設(shè)置對象,用來說明如何構(gòu)造XHR對象。

      $http({
      method:'GET',
      url:'/api/users.json',
      params:{
      'username':'tan'
      });
       
      其中設(shè)置對象可以包含以下主要的鍵:
      ①method
      可以是:GET/DELETE/HEAD/JSONP/POST/PUT

      ②url:絕對的或者相對的請求目標(biāo)
      ③params(字符串map或者對象)
      這個鍵的值是一個字符串map或?qū)ο?,會被轉(zhuǎn)換成查詢字符串追加在URL后面。如果值不是字符串,會被JSON序列化。
      比如這個:

      //參數(shù)會轉(zhuǎn)為?name=ari的形式
      $http({
      params:{'name':'ari'}
      });

      ④data(字符串或者對象)
      這個對象中包含了將會被當(dāng)作消息體發(fā)送給服務(wù)器的數(shù)據(jù)。通常在發(fā)送POST請求時使用。

      從AngularJS 1.3開始,它還可以在POST請求里發(fā)送二進制數(shù)據(jù)。要發(fā)送一個blob對象,你可以簡單地通過使用data參數(shù)來傳遞它。
      例如:
      var blob=new Blob(['Hello world'],{type:'text/plain'});
      $http({
      method:'POST',
      url:'/',
      data:blob
      });

      4、響應(yīng)對象

      AngularJS傳遞給then()方法的響應(yīng)對象包含了四個屬性。
      ◇data
      這個數(shù)據(jù)代表轉(zhuǎn)換過后的響應(yīng)體(如果定義了轉(zhuǎn)換的話)
      ◇status
      響應(yīng)的HTTP狀態(tài)碼
      ◇headers
      這個函數(shù)是頭信息的getter函數(shù),可以接受一個參數(shù),用來獲取對應(yīng)名字值

      例如,用如下代碼獲取X-Auth-ID的值:
      $http({
      method: 'GET',
      url: '/api/users.json'
      }).then (resp) {
      // 讀取X-Auth-ID
      resp.headers('X-Auth-ID');
      });

      ◇config
      這個對象是用來生成原始請求的完整設(shè)置對象。

      ◇statusText(字符串)
      這個字符串是響應(yīng)的HTTP狀態(tài)文本。

      5、緩存HTTP請求
      默認(rèn)情況下,$http服務(wù)不會對請求進行本地緩存。在發(fā)送單獨的請求時,我們可以通過向$http請求傳入一個布爾值或者一個緩存實例來啟用緩存。
      $http.get('/api/users.json',{ cache: true })
      .success(function(data) {})
      .error(function(data) {});

      第一次發(fā)送請求時,$http服務(wù)會向/api/users.json發(fā)送一個GET請求。第二次發(fā)送同一個GET請求時,$http服務(wù)會從緩存中取回請求的結(jié)果,而不會真的發(fā)送一個HTTP GET請求。
      在這個例子里,由于設(shè)置了啟用緩存,AngularJS默認(rèn)會使用$cacheFactory,這個服務(wù)是AngularJS在啟動時自動創(chuàng)建的。

      如果想要對AngularJS使用的緩存進行更多的自定義控制,可以向請求傳入一個自定義的緩存實例代替true。

        本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多