• AJAX常用参数
  • AJAX对象兼容
  • AJAX对象方法与属性
  • AJAX封装兼容方法源码

AJAX全称Asynchronous JavaScript and XML(异步的JavaScript与XML),最初的AJAX传输的数据格式采用的是XML,所以这也就是AJAX名称的由来,后来由于技术的发展JSON更被接受,现在的AJAX传输数据格式改用的都是JSON格式。其实最初的浏览器并不支持AJAX技术,这些与需求安全技术等等因素相关,这里就不太深入的赘述,值得关注的是AJAX本身实质上就是HTTP网络访问协议通过浏览器内核暴露的接口,通过AJAX对象可以由用户主动通过调用对象的相关方法发起网络请求,浏览器并且会对发起的网络请求进行监听,实现AJAX响应机制。而且AJAX还可以主动添加HTTP报文头,实现多样的网络请求。

一、AJAX常用参数

1. HTTP请求方法(method):GET、HEAD、POST、PUT、TRACE、OPTIONS、DELETE和Web扩展方法[LOCK、MKCOL、COPY、MOVE]。这些方法不一定都能被正常使用,需要看具体的网络服务程序是否实现。常用的方法就是GET和POST。

2. HTTP请求URL: 请求资源的路径。

3. HTTP请求的主体部分:(data)通常描述的数据,由请求方发送给接受方的数据(我封装的方法中采用的是接收键值对(对象)形式的数据,内部处理成字符串拼接的处理方式)。

4. 浏览器采用异步或同步发送请求(flag/async):true表示异步,false表示同步。

5. 请求响应的回调方法:callback。由具体AJAX请求事件实现。

二、AJAX对象兼容

AJAX最先被应用到浏览器中的是微软实现的,所以在IE5和IE6中的AJAX对象是ActiveXObject,后来由W3C规范统一为XMLHttpRequest。下面是兼容代码:

var  xhr = null ;
if(window.XMLHttpRequest) {
//创建除IE以外的ajax对象 --- code f for IE7+, Firefox, Chrome, Opera, Safari
xhr = new XMLHttpRequest() ;
}else{
//创建IE的ajax对象 --- code for IE6, IE5
xhr = new ActiveXObject("Microsoft.XMLHttp");
}

三、AJAX方法与属性

1. xhr.open(method,url,async);用来初始化请求对象的请求。

2. xhr.send(string);将请求发送给接受方,其参数只适应post方法的请求,传入的是请求报文的主体(数据)。其他请求方法将数据拼接在URL后面。

//GET请求方法
xhr.open('GET',url+'?'+data,flag);
xhr.send();
//POST请求方法
xhr.open(method,url,flag);
xhr.setRequestHeader('Content-type','application/x-www-form-urlencoded');
xhr.send(data);
//data格式
"name='xiaoming'&sex='man'"

3. xhr.setRequestHeader(header,value);给HTTP请求报文添加头部字段,参数1:头部名称;参数2:头部的值。这里添加的传输主体(data)发送到服务器之前应该如何对数据进行编码。示例中的application/x-www-form-urlencoded编码类型的发送和接收,窗体数据被编码为名称/值对。还有application/json的发送和接收,表示窗体数据被编码为JSON字符串。multipart/form-data的发送和接收,表示窗体数据被编码为文件编码格式(适应文件、图片等传输)。HTTP头部还有其他很多属性,Content-type数据编码格式也还有其他的格式,就不在这里一一列举了。

4. xhr.onreadystatechange是AJAX请求响应监听事件,每当xhr.readyState的属性值发生改变时就会被触发一次。

5. xhr.readyState存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

  • 0: 请求未初始化
  • 1: 服务器连接已建立
  • 2: 请求已接收
  • 3: 请求处理中
  • 4: 请求已完成,且响应已就绪

6. xhr.status表示HTTP响应的状态码。

  • 200: (OK)表示请求成功,所请求的数据都在响应主体中。(200~299)
  • 401: (Unauthorized)表示未授权,需要输入用户民和密码。
  • 404: (Not Found)表示未找到执行的资源,也就是说请求的资源在服务器中没有找到。
  • 300~399: 重定向,已定义的范围(300~305)。
  • 400~499: 客户端错误,已定义的范围(400~415)。
  • 500~599: 服务器出错,已定义的范围(500~505)。

7. xhr.responseText获取字符串形式的响应数据。

8. xhr.responseXML获取XML形式的响应数据。

四、AJAX兼容方法封装源码

 function ajaxFunc(method,url,data,callback,flag){
//参数:method(提交请求方法):get、post;
// url(提交地址):服务器地址;
// data(提交数据):采用Object数据类型,当get请求模式时转换为字符串拼接形式,当post请求模式时转换为JSON数据格式;
// callback(处理服务器响应数据的方法);
// flag(异步还是同步提交):true(异步)、false(同步); //创建一个ajax对象
let xhr = null;
if(window.XMLHttpRequest){
// 创建除IE以外的ajax对象 -- code f for IE7+, FireFox, Chrome, Opera, Safari
xhr = new XMLHttpRequest();
}else{
// 创建兼容IE的ajax对象 -- code for IE6, IE5
xhr = new ActiveXObject("Microsoft.XMLHttp");
}
//将get、post转成大写
method = method.toUpperCase();
//发起ajax请求
if(method === 'GET'){
//将dta的JSON格式数据转换拼接成可直接提交的字符串形式
data = (function(data){
let httpText = "";
if(!data){
return null;
}
for(let temp in data){
httpText = httpText + (temp + '=' + data[temp] + '&');
}
return httpText;
})(data);
//发起GET方法的请求
xhr.open(method, url + '?' + data, flag);
xhr.send(null);
}else if(method === 'POST'){
//发起POST方法的请求
xhr.open(method, url, flag);
xhr.setRequestHeader('Content-type','application/x-www-form-urlencoded');
xhr.send(JSON.stringify(data));
}
//监听物理信息
xhr.onreadystatechange = function(){
// 监听到readystate=4时
// 解析服务器返回的responseText数据
if(xhr["readyState"] === 4){
//判断响应状态是否为200--表示请求成功响应
if(xhr["status"] === 200){
callback(xhr["responseText"]);
}
}
}
}

AJAX原理解析与兼容方法封装的更多相关文章

  1. 原生ajax的get和post方法封装

    get 方法 function serialize (data) { if (!data) { return ''; } var paris = []; for (var key in data) { ...

  2. 通用ajax请求方法封装,兼容主流浏览器

    ajax简单介绍 没有AJAX会怎么样?普通的ASP.Net每次运行服务端方法的时候都要刷新当前页面. 假设没有AJAX,在youku看视频的过程中假设点击了"顶.踩".评论.评论 ...

  3. Ajax跨域:Jsonp原理解析

    推荐先看下这篇文章:JS跨域(ajax跨域.iframe跨域)解决方法及原理详解(jsonp) JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重 ...

  4. Ajax原理,技术封装与完整示例代码

    在做项目和学习的时候,经常用到Ajax的相关技术,但是这方面的技术总是运用的不是十分好,就寻找相关博客来学习加深Ajax技术相关. 一.Ajax简介 二.同步.异步传输区别 2.1 异步传输 2.2 ...

  5. 封装ajax原理

    封装ajax原理 首先处理 用户如果不传某些参数,设置默认值 type默认get 默认url为当前页 默认async方式请求 data数据默认为{} 处理用户传进来的参数对象 遍历,拼接成key=va ...

  6. 使用es6的then()方法封装jquery的ajax请求

    使用场景: jsp页面中使用jquery的ajax请求比较频繁,以前vue框架的项目用过axios,所以就想着用then()封装一个公共请求的方法,这样每次请求就不用那么麻烦的写一大堆请求参数了. 示 ...

  7. 深入解析ThreadLocal 详解、实现原理、使用场景方法以及内存泄漏防范 多线程中篇(十七)

    简介 从名称看,ThreadLocal 也就是thread和local的组合,也就是一个thread有一个local的变量副本 ThreadLocal提供了线程的本地副本,也就是说每个线程将会拥有一个 ...

  8. 【前端学习笔记04】JavaScript数据通信Ajax方法封装

    //Ajax 方法封装 //设置数据格式 function setData(data){ if(!data){ return ''; } else{ var arr = []; for(k in da ...

  9. Ajax原理一篇就够了

    Ajax原理一篇就够了 一.什么是Ajax Ajax(Asynchronous JavaScript and XML的缩写)是一种异步请求数据的web开发技术,对于改善用户的体验和页面性能很有帮助.简 ...

随机推荐

  1. RabbitMQ for Mac OS Install

    使用brew来安装 RabbitMQ brew install rabbitmq 执行看到如下命令: Updating Homebrew... ==> Auto-updated Homebrew ...

  2. git错误--ssh: Could not resolve hostname ssh.github.com: Name or service not known--解决方式

    错误如下: git push origin ssh: Could not resolve hostname ssh.github.com: Name or service not known fata ...

  3. python之控制流

    https://www.cnblogs.com/evablogs/p/6691776.html 条件判断 简单if语句 1 2 3 4 5 >>>name='lily' >&g ...

  4. Python基础之元组

    元组初识 元组的认识 首先,我们来认识一下元组: # 定义一个元组 uesr_tuple = ("zhangsan", "lisi", "wangwu ...

  5. 对ES6的yield示例分析

    近期ES6标准如火如荼的发展,其中主要还是各大浏览器的支持,最重要厂商支付宝,微信的支持,使得国内的发展也很迅猛. 这里主要是对yield关键字的,yield实际上可以看作是一种新的中断机制,大家都知 ...

  6. 利用unittest+ddt进行接口测试(一):简单demo

    一般进行接口测试时,每个接口的传参都不止一种情况,一般会考虑正向.逆向等多种组合.所以在测试一个接口时通常会编写多条case,而这些case除了传参不同外,其实并没什么区别. 这个时候就可以利用ddt ...

  7. 分布式存储ceph——(1)部署ceph

    前言: 很多朋友想学ceph,但是开始ceph部署就让初学者举步为艰,ceph部署时由于国外源的问题(具体大家应该懂得),下载和安装软件便会卡住,停止不前.即使配置搭建了国内源后,执行ceph-dep ...

  8. Neutron:浮动ip

    如果需要从外网直接访问 instance,则可以利用 floating IP.   下面是关于 floating IP 必须知道的事实: 1. floating IP 提供静态 NAT 功能,建立外网 ...

  9. Linux如何在一个文件中写入内容

    Linux中,在一个文件中写入内容,可以vim打开编辑模式,输入我们想要的内容,此次我们使用echo命令 来在一个文件夹中写入内容. echo命令: 第一种: echo 'i love u' > ...

  10. Web项目中的 /

    如果 /  出现在路径的前面: web.xml中:http://loclalhost:8080/项目名称/      在项目的根路径下面 jsp中: http://localhost:8080/    ...