原生js请求http接口
程序员文章站
2022-04-14 20:42:16
...
<script>
//obj :{method:"get",url:"",data:{}};
function httpRequest(obj,successfun,errFun){
var xmlHttp = null;
//创建 XMLHttpRequest 对象,老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 对象:xmlhttp=new ActiveXObject("Microsoft.XMLHTTP")
if(window.XMLHttpRequest){
//code for all new browsers
xmlHttp = new XMLHttpRequest;
}else if(window.ActiveXObject){
//code for IE5 and IE6
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
//判断是否支持请求
if(xmlHttp == null){
alert("浏览器不支持xmlHttp");
return;
}
//请求方式, 转换为大写
var httpMethod = (obj.method || "Get").toUpperCase();
//数据类型
var httpDataType = obj.dataType||'json';
//url
var httpUrl = obj.url || '';
//异步请求
var async = true;
//post请求时参数处理
if(httpMethod=="POST"){
//请求体中的参数 post请求参数格式为:param1=test¶m2=test2
var data = obj.data || {};
var requestData = '';
for(var key in data){
requestData = requestData + key + "=" + data[key] + "&";
}
if(requestData == ''){
requestData = '';
}else{
requestData = requestData.subString(0,requestData.length - 1);
}
console.log(requestData);
}
//onreadystatechange 是一个事件句柄。它的值 (state_Change) 是一个函数的名称,当 XMLHttpRequest 对象的状态发生改变时,会触发此函数。状态从 0 (uninitialized) 到 4 (complete) 进行变化。仅在状态为 4 时,我们才执行代码
xmlHttp.onreadystatechange = function(){
//complete
if(xmlHttp.readyState == 4){
if(xmlHttp.status == 200){
//请求成功执行的回调函数
successfun(xmlHttp.responseText);
}else{
//请求失败的回调函数
errFun;
}
}
}
//请求接口
if(httpMethod == 'GET'){
xmlHttp.open("GET",httpUrl,async);
xmlHttp.send(null);
}else if(httpMethod == "POST"){
xmlHttp.open("POST",httpUrl,async);
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
xmlHttp.send(requestData);
}
}
</script>
/**
测试代码
*/
<script>
httpRequest({
method:"post",
url:"",//请求的url地址
data:{
param1:''
}
},function(res){
console.log(res);
},function(){
console.log("请求失败");
});
</script>
上一篇: php 学习 1
下一篇: org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation; uncategorized SQLExcepti
推荐阅读
-
微信小程序HTTP接口请求封装的实现
-
微信小程序HTTP接口请求封装代码实例
-
原生js jquery ajax请求以及jsonp的调用方法
-
node.js中express模块创建服务器和http模块客户端发请求
-
C#处理和对接HTTP接口请求的方法
-
第一个 node js http 发送post请求(测试无误)
-
Node.js中的http请求客户端示例(request client)
-
android 请求接口报错 org.apache.http.conn.HttpHostConnectException: Connection to http://192.168.1.90:9090 refused
-
原生js 封装get ,post, delete 请求的实例
-
原生JS写Ajax的请求函数功能