原生js的ajax

在移动端很多时候对于dom操作不是很频繁,只用到ajax进行简单的数据交互,但是引入jquery的几十k大小代价有点大,但jquery的$.post()却非常的好用,仅仅一行代码就能很方便的与后台交互,所以自己写了个原生的ajax 方便使用。

先定义一个函数post(url,param,callback){} 哈哈 参数都跟jquery一样的有木有。

var xmlhttp = new XMLHttpRequest(); 先定义一个请求对象,然后给他绑定事件

xmlhttp.onreadystatechange = function(){

  if(this.readyState == 4 && this.status == 200){  //请求成功的状态码

    callback(JSON.pares(xmlhttp.responseText));  //后台一般传过来的是json字符串,需要给他转成json对象

  }

};

xmlhttp.open('post',url,true);  //请求方式,地址,是否异步

xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");  //这个是post请求需要带的

xmlhttp.setRequestHeader("If-Modified-Since", "0");    //这个加上不缓存数据 no-cache

var paraStr = '';

 

for (key in param){

  paraStr += key+"="+encodeURIComponent(param[key])+"&";  //因为如果要和jquery一样参数是json对象,需要循环读出拼接字符串

}

paraStr = paraStr.substr(0,paraStr.length-1);

xmlhttp.send(paraStr);  //然后把字符串带过去并发送请求 如果是get方式的话直接把参数带在url后面

是不是很简单呢?

如果你觉得这篇随笔对你有帮助可以支付宝(左)或微信(右)打赏小毅喝杯咖啡 ^_^

转载于:https://www.cnblogs.com/songsony/p/5140276.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值