最近看了下《Javascript高级程序设计》(第三版)关于Ajax部分,做了这篇笔记。

一、常规用法

第一步,创建XHR对象
var xhr = new XMLHttpRequest();
此方法兼容IE7+, 针对IE6需要使用new ActiveXObject("Microsoft.XMLHTTP");

第二步,准备请求
xhr.open("get","/testajax",false);
参数分别为: 请求类型 、url、是否异步

第三步,发送请求
get请求的话就是xhr.send(null)
send需要一个参数,因为get请求中参数会在url中,所以这里写null(之所以写null是因为不写的话在某些浏览器会有问题)。
如果是post请求,那么这里面就写post请求需要的参数。
但是首先需要设置content-type,例如:
xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");
然后发送数据xhr.send("fname=Bill&lname=Gates");

第四步,请求发出去后,服务器响应的内容会自动填充到xhr对象的属性上
有这些属性
responseText 返回的文本
responseXML 如果content-type为"text/xml'或者"application/xml"就把数据放这个属性
status HTTP状态码
statusText 状态说明

第五步、根据status检查请求状态
if((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304){
alert(xhr.responseText )
}else{}

无论类型是什么,响应主题内容都会保存在responseText属性中。
对于非xml格式数据而言,responseXML为null。

第六步,如果是异步请求,那么需要监听readyState来判断请求的状态
通过onreadystatuschange事件判断readyState的值

xhr.onreadystatechange = function(){
if(xhr.readyState == 4){
console.log("success")
}
};

其他注意点:
setRequestHeader用来设置头信息
getResponseHeader得到响应头信息
getAllResponseHeaders得到全部响应头信息

get请求中,对参数使用encodeURIComponent方法

post请求中,设置content-type,参数序列化传入,格式和get请求一样
如果不设置content-type,那么后台就必须从raw request header中去得到参数

二、xhr2中的功能

1: FormData()序列化表单数据
var data = new FormData();
data.append("hello","world");
xhr.send(data);
或者
xhr.send(document.forms[0])
这样可以快速传入post参数,而且无需设置content-type。

2: timeout超时
xhr.timeout = 1000; //设置超时时间
xhr.ontimeout = function(){}; //处理超时情况
xhr.send(null);

3:overrideMimeType
重写MIME,MIME决定了你的responseXML或者responseText的值是否存在
MIME由content-type设置

4:进度事件,用来监视xhr的进度。
提供了一系列的事件,可以做类似网页加载进度条的效果。

三、跨域
CORS实现ajax的跨域访问

1: 标准的实现:
首先,先发送一个跨域ajax请求(这里可以检测是否支持CORS,通过新建一个xhr对象,检测xhr2中的属性是否存在在这个对象来实现)。
然后,普通情况下,我们肯定会发现控制台报错,类似无法访问跨域资源这种错误。
这时需要服务器设置
Access-Control-Allow-Origin:* 代表所有域名都可以访问到
Access-Control-Allow-Origin: http://www.cnblogs.com 限定了域名
请求和响应均不包含cookie信息

2: IE的实现:
通过XDomainRequest()来实现。
直接改变contenttype属性来实现post请求
xdr.contentType= "";
不能发送同步请求

3: 自定义头部:
在CORS中是不支持的,但是有固定接口可以设置的头部来传输信息。

4: 带凭证的请求(cookie、ssl等):
客服端通过withCredentials设置为true来实现
服务器返回相应的头部来确认即可。

四、其他跨域技术

1: 动态创建一个图片,src跨域,然后可以返回一个像素图或者204;
返回后的处理在onload和onerror里面
可以用于一些数据统计方面。

2: JSONP

五、服务器推送
1、轮询
2、长轮询
3、HTTP流
4、SSE
5、Web Sockets
先发一个http请求过去,服务器相应后会把http协议变为web socket协议
链接变为 ws://
var socket = new WebSocket("ws://xxx.com")
没有同源限制
通过 socket.readyState 来判断链接状态
socket.close()关闭

数据交互
socket.send("xxx");发送消息
消息内容只能是纯文本,所以对于复杂的数据需要序列化
socket.onmessage = function(event){
var data = event.data; //这里是服务器返回的数据
}

整理Ajax的点点滴滴的更多相关文章

  1. [整理]Ajax Post请求下的Form Data和Request Payload

    Ajax Post请求下的Form Data和Request Payload 通常情况下,我们通过Post提交表单,以键值对的形式存储在请求体中.此时的reqeuest headers会有Conten ...

  2. 前端面试题整理—ajax篇

    1.什么是Ajax和JSON,它们的优缺点 Ajax是全称是asynchronous JavaScript andXML,即异步JavaScript和xml,用于在Web页面中实现异步数据交互,实现页 ...

  3. 记录AJAX充电点点滴滴

    首先要明白什么是 AJAX ? AJAX = 异步 JavaScript 和 XML. AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更 ...

  4. 框架基础:ajax设计方案(一)---集成核心请求

    报告,我要说话!xp被历史淘汰了,IE6 say goodbye了,太TM开心了,从此不要兼容IE6了,哈哈哈哈哈哈 报告,我要说话!IE这sb为啥不早点被杀掉呢,找工作听说要兼容IE,立马软了,唉唉 ...

  5. 前端通信:ajax设计方案(一)---集成核心请求

    报告,我要说话!xp被历史淘汰了,IE6 say goodbye了,太TM开心了,从此不要兼容IE6了,哈哈哈哈哈哈 报告,我要说话!IE这sb为啥不早点被杀掉呢,找工作听说要兼容IE,立马软了,唉唉 ...

  6. Django web 基础

    一.Django概述 Django大而全; 创建Django工程:django-admin startproject sitename 创建django之后生成的目录结构如下: Project Pro ...

  7. 经典技术之URL

    SpringBoot入门 (十) 发送邮件 图表算法—最短路径 三个好用的并发工具类 跨应用Session共享: https://www.cnblogs.com/websharing/p/849586 ...

  8. Backbone Model 源码简谈 (版本:1.1.0 基础部分完毕)

    Model工厂   作为model的主要函数,其实只有12行,特别的简练 var Model = Backbone.Model = function(attributes, options) { va ...

  9. Ajax学习整理

    什么是ajax?W3School中给ajax的定义是: 1.AJAX = 异步 JavaScript 和 XML. 2.AJAX 是一种用于创建快速动态网页的技术. 3.通过在后台与服务器进行少量数据 ...

随机推荐

  1. Http状态码之:301、302重定向

    概念 301 Moved Permanently 被请求的资源已永久移动到新位置,并且将来任何对此资源的引用都应该使用本响应返回的若干个URI之一.如果可能,拥有链接编辑功能的客户端应当自动把请求的地 ...

  2. ASP.NET Core 之 Identity 入门(三)

    前言 在上一篇文章中,我们学习了 CookieAuthentication 中间件,本篇的话主要看一下 Identity 本身. 最早2005年 ASP.NET 2.0 的时候开始, Web 应用程序 ...

  3. UWP学习目录整理

    UWP学习目录整理 0x00 可以忽略的废话 10月6号靠着半听半猜和文字直播的补充看完了微软的秋季新品发布会,信仰充值成功,对UWP的开发十分感兴趣,打算后面找时间学习一下.谁想到学习的欲望越来越强 ...

  4. iOS---iOS10适配iOS当前所有系统的远程推送

    一.iOS推送通知简介 众所周知苹果的推送通知从iOS3开始出现, 每一年都会更新一些新的用法. 譬如iOS7出现的Silent remote notifications(远程静默推送), iOS8出 ...

  5. .Net Core MVC 网站开发(Ninesky) 2.3、项目架构调整-控制反转和依赖注入的使用

    再次调整项目架构是因为和群友dezhou的一次聊天,我原来的想法是项目尽量做简单点别搞太复杂了,仅使用了DbContext的注入,其他的也没有写接口耦合度很高.和dezhou聊过之后我仔细考虑了一下, ...

  6. .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator

    去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...

  7. .net erp(办公oa)开发平台架构概要说明之表单设计器

    背景:搭建一个适合公司erp业务的开发平台.   架构概要图: 表单设计开发部署示例图    表单设计开发部署示例说明1)每个开发人员可以自己部署表单设计至本地一份(当然也可以共用一套开发环境,但是如 ...

  8. Xamarin+Prism开发详解三:Visual studio 2017 RC初体验

    Visual studio 2017 RC出来一段时间了,最近有时间就想安装试试,随带分享一下安装使用体验. 1,卸载visual studio 2015 虽然可以同时安装visual studio ...

  9. 免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)

    前面介绍了六种.NET组件,其中有一种组件是写文件的压缩和解压,现在介绍另一种文件的解压缩组件SharpZipLib.在这个组件介绍系列中,只为简单的介绍组件的背景和简单的应用,读者在阅读时可以结合官 ...

  10. jQuery的属性

    The Write Less , Do More ! jQuery的属性 1. attr(name|properties|key,value|fn) : 设置或返回被选元素的属性值 ①获取属性 < ...