自从javascript有了各种框架之后,比如jquery,使用ajax已经变的相当简单了。但有时候为了追求简洁,可能项目中不需要加载jquery这种庞大的js插件。但又要使用到ajax这种功能该如何办呢?下面和大家分享javascript实现原生ajax的方法。

实现ajax之前必须要创建一个 XMLHttpRequest 对象。如果不支持创建该对象的浏览器,则需要创建 ActiveXObject,具体方法如下:

var xmlHttp;
function createxmlHttpRequest() {
if (window.ActiveXObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} else if (window.XMLHttpRequest) {
xmlHttp=new XMLHttpRequest();
}

(1)下面使用上面创建的xmlHttp实现最简单的ajax get请求:

function doGet(url){
// 注意在传参数值的时候最好使用encodeURI处理一下,以防出现乱码
createxmlHttpRequest();
xmlHttp.open("GET",url);
xmlHttp.send(null);
xmlHttp.onreadystatechange = function() {
if ((xmlHttp.readyState == 4) && (xmlHttp.status == 200)) {
alert('success');
} else {
alert('fail');
}
}
}

(2)使用上面创建的xmlHttp实现最简单的ajax post请求:

function doPost(url,data){
// 注意在传参数值的时候最好使用encodeURI处理一下,以防出现乱码
createxmlHttpRequest();
xmlHttp.open("POST",url);
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
xmlHttp.send(data);
xmlHttp.onreadystatechange = function() {
if ((xmlHttp.readyState == 4) && (xmlHttp.status == 200)) {
alert('success');
} else {
alert('fail');
}
}
}

最新文章

  1. Web 前端攻防(2014版)
  2. cocoapods
  3. int与string类型的转换
  4. weight属性你用的真的6嘛?
  5. 国内好用的maven仓库,添加到本地nexus中
  6. hadoop机架感知与网络拓扑分析:NetworkTopology和DNSToSwitchMapping
  7. [技术分享] .NET下 , 上传图片的处理方式 , 贴上代码 .
  8. javascript高级教程:如何优化javascript代码性能
  9. 带宽计算-大B与小b的区别
  10. JS 格式化日期
  11. 表达式:使用API创建表达式树(5)
  12. Linux on Power 上的调试工具和技术
  13. php多图合并
  14. js原生继承之——构造函数式继承实例
  15. 【Uva10559】Blocks(区间DP)
  16. JDBC连接
  17. DELL服务器r710配置RAID
  18. JDK7与8内存参数解析与修改
  19. 实录分享 | 计算未来轻沙龙:揭秘AutoML技术(视频 + PPT)
  20. 使用WPF Animated GIF实现GIF图片的播放

热门文章

  1. mount/umount命令【转】
  2. Tomcat+Apache 负载均衡
  3. IE8下面的line-height的bug
  4. 我的新博客地址http://xxxbw.github.io/
  5. git 查看父分支
  6. 二、ansible配置简要介绍
  7. Django在根据models生成数据库表时报错
  8. HAProxy配置代理
  9. Word中截取部分内容并保存为jpg图片的方法
  10. AC日记——妖梦斩木棒 洛谷 P3797