angularjs封裝$http為factory的方法,angularjsfactory

來源:互聯網
上載者:User

angularjs封裝$http為factory的方法,angularjsfactory

angularjs有本身封裝的ajax服務$http,因為用慣了jQuery的ajax,所以,自己封裝了一下angularjs的$http,代碼如下

app.factory('dataFactory', function ($http, $q){   var factory = {};   factory.getlist = function(endpoint, method, headers, params) {     var defer = $q.defer();     if (method == 'GET') {       $http({         url: endpoint,         method: "GET",         headers: headers,         params: params,       }).success(function (data) {         defer.resolve(data);       }).       error(function (data, status, headers, config) {         // defer.resolve(data);         defer.reject(data);       });     } else {       $http({         url: endpoint,         method: method,         headers: headers,         data: params,       }).success(function (data) {         defer.resolve(data);       }).       error(function (data, status, headers, config) {         // defer.resolve(data);         defer.reject(data);       });     }     return defer.promise;     };     return factory; }); 

在controller中引入dataFactory和$http即可使用更方便的調用ajax,一般情況下headers為

headers = {'Content-Type': 'application/json'};

params為一個json字串

然後調用

dataFactory.getlist("/api/checkDuplicate", 'GET', headers, params).then(function(data) { //success函數 },function(data){ //error函數 }) 

但是其中又一次在項目中,後台架構使用的是Struts架構,在一個Python中使用的很好的dataFactory,在這裡的後台取不到數,最後發現是應為header設定不對,而且params的格式也不正確,可以把header修改為

 headers = {'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'};

上面dataFactory中else添加轉換params代碼:

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;         };       $http({         url: endpoint,         method: method,         headers: headers,         data: param(params),       }).success(function (data) {         defer.resolve(data);       }).       error(function (data, status, headers, config) {         // defer.resolve(data);         defer.reject(data);       }); 

只是個人覺得這個方式比較方便,記錄下來,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.