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程序设计有所帮助。
上一篇: AI怎么使用剪切蒙版剪切星星图形?
下一篇: 颈椎病治疗方法 六种按摩方法保护颈椎