欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Angularjs中$http以post请求通过消息体传递参数的实现方法

程序员文章站 2023-10-30 09:01:04
本文实例讲述了angularjs中$http以post请求通过消息体传递参数的方法。分享给大家供大家参考,具体如下: angularjs中,$http以post在消息体中...

本文实例讲述了angularjs中$http以post请求通过消息体传递参数的方法。分享给大家供大家参考,具体如下:

angularjs中,$http以post在消息体中传递参数,需要做以下修改,以确保消息体传递参数的正确性。

一、在声明应用的时候进行设置:

var httppost = function($httpprovider) {
  /*******************************************
  说明:$http的post提交时,纠正消息体
  ********************************************/
  // use x-www-form-urlencoded content-type
  $httpprovider.defaults.headers.post['content-type'] = 'application/x-www-form-urlencoded;charset=utf-8';
  /*
   * the workhorse; converts an object to x-www-form-urlencoded serialization.
   * @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;
  };
  // override $http service's default transformrequest
  $httpprovider.defaults.transformrequest = [
    function(data) {
      return angular.isobject(data) && string(data) !== '[object file]' ? param(data) : data;
    }
  ];
};
var ngapp = angular.module('wtapp', ['ngcookies'], httppost);

二、调用$http post

$http({
  method: 'post',
  url: 'getdata.ashx',
  params: { id: '1002' },//params作为url的参数
  data: { keyname: 'qubernet' }//作为消息体参数
}, function (data) {
});

希望本文所述对大家angularjs程序设计有所帮助。