从屌丝到架构师的飞越(JavaScript篇)-JavaScript 原生Ajax请求

一、介绍

这节课呢,我们来了解的是JavaScript 原生Ajax请求,

Ajax,是Asynchronous  JavaScript + XML 的简写,可以实现页面的局部刷新。虽然 Ajax 中的 x 代表的是 XML,但 Ajax 通信和数据格式无关,所以传输的数据格式不一定使用 XML。

AJAX 不是新的编程语言,而是一种使用现有标准的新方法。AJAX 即 Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。它可以在不重新加载整个页面的情况下完成与服务器交换数据并更新部分网页。

AJAX 是一种用于创建快速动态网页的技术。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。所有现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)。

一个完整的AJAX请求包括五个步骤:

1.  创建XMLHTTPRequest对象

2.  使用open方法创建http请求,并设置请求地址

3.  设置发送的数据,开始和服务器端交互

4.  注册事

5.  获取响应并更新界面

二、知识点介绍

1、Ajax简介

2、工作原理

3、XMLHttpRequest

4、open()方法

5、send()方法

6、服务器响应

7、readystatechange 事件

8、头信息

9、编码处理

10、封装Ajax

三、上课对应视频的说明文档

1、Ajax简介

ajax = 异步 JavaScript 和 XML。

ajax是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。我们知道,传统的网页(不使用ajax)如果需要更新内容,必须重新加载整个网页。Ajax的出现,使得使网可以实现异步更新,这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

注意:ajax本身不支持跨域请求,需要在服务器端处理。

2、工作原理

ajax的技术核心是 XMLHttpRequest 对象。

ajax请求过程:创建XMLHttpRequest、连接服务器、发送请求、服务器做出响应、接收响应数据

图示:

3、XMLHttpRequest

Ajax 技术核心是XMLHttpRequest 对象(简称 XHR)。

IE7+、Firefox、Opera、Chrome 和 Safari 都支持原生的 XHR 对象,在这些浏览器中创建XHR 对象可以直接实例化 XMLHttpRequest 即可。

var xhr =new XMLHttpRequest();

注意:通常在使用IE内核的浏览器时,我们通过以下代码创建XHR 对象。

var xhr;               

if(window.XMLHttpRequest){

xhr=newXMLHttpRequest();

}else{            //表示使用的是IE的老版本内核

xhr=newActiveXObject("Microsoft.XMLHTTP");

}

4、open()方法

在使用 XHR 对象时,先必须调用open()方法,它接受三个参数:要发送的请求类型(get 、post)、请求的 URL 和表示是否异步。

xhr.open(‘post’, 'test.jsp’, false); //对于test.jsp 的 get 请求,false 同步

open()方法并不会真正发送请求,而只是启动一个请求以备发送。

5、send()方法

通过 send()方法进行发送请求,send()方法接受一个参数,作为请求主体发送的数据。如果不需要则,必须填 null 。执行 send()方法之后,请求就会发送到服务器上。

xhr.send(null); //发送请求

6、服务器响应

当请求发送到服务器端,收到响应后,响应的数据会自动填充 XHR 对象的属性。那么一共有四个属性:

responseText :作为响应主体被返回的文本

responseXML :如果响应主体内容类型是"text/xml"或"application/xml",则返回包含响应数据的 XML DOM 文档

status :响应的 HTTP 状态

statusText : HTTP 状态的说明

接受响应之后,第一步检查 status 属性,以确定响应已经成功返回。一般而已 HTTP 状态代码为200 作为成功的标志。当然了还有其他的状态码,如下:

HTTP状态码 状态字符串  说明

200 OK  服务器成功返回了页面

400 Bad Request 语法错误导致服务器不识别

401 Unauthorized    请求需要用户认证

404 Not found  指定的 URL 在服务器上找不到

500 Internal Server Error  服务器遇到意外错误,无法完成请求

503 ServiceUnavailable  由于服务器过载或维护导致无法完成请求

7、readystatechange 事件

同步的情况下,js会等待请求返回,获取status。不需要onreadystatechange事件处理函数。而异步则需要onreadystatechange事件处理,且值为4再正确处理下面的内容。

如:同步的情况下:

var xhr = new createXHR();

xhr.open('get', 'test.jsp?rand=' +Math.random(), false); //设置了同步

xhr.send(null);

if (xhr.status == 200) { //如果返回成功了

alert(xhr.responseText);//调出服务器返回的数据

} else {

alert('数据返回失败!状态代码:'+ xhr.status + '状态信息:' + xhr.statusText);

}

异步的情况下:

var xhr = new createXHR();

xhr.onreadystatechange = function () {

if (xhr.readyState == 4) {

if (xhr.status == 200) {

alert(xhr.responseText);

} else {

alert('数据返回失败!状态代码:'+ xhr.status + '状态信息:'+ xhr.statusText);

}

}

};

xhr.open('get', 'test.jsp?rand=' +Math.random(), true);//设置异步传输

xhr.send(null);

注意:readyState属性除了可以是4,还可以是其它值,如下表:

值  状态  说明

0  未初始化    尚未调用 open()方法

1  启动  已经调用 open()方法,但尚未调用 send()方法

2  发送  已经调用 send()方法,但尚未接受响应

3  接受  已经接受到部分响应数据

4  完成  已经接受到全部响应数据,而且可以使用

8、头信息

8.1、使用 setRequestHeader()设置单个请求头信息

//放在 open 方法之后,send 方法之前

如:xhr.setRequestHeader("content-type","text/xml;charset=utf-8");

注意:POST 请求和 Web 表单提交是不同的,需要使用 XHR 来模仿表单提交。

xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');

8.2、使用 getResponseHeader()获取单个响应头信息

alert(xhr.getResponseHeader('Content-Type'));

8.3、使用 getAllResponseHeaders()获取整个响应头信息

alert(xhr.getAllResponseHeaders());

9、编码处理

特殊字符传参产生的问题可以使用 encodeURIComponent()进行编码处理,中文字符的返回及传参,可以讲页面保存和设置为 utf-8 格式即可。

//一个通用的 URL 提交函数

function addURLParam(url, name, value) {

url +=(url.indexOf('?') == -1 ? '?' : '&'); //判断的 url 是否有已有参数

url += encodeURIComponent(name) + '=' + encodeURIComponent(value);

alert(url);

return url;

}

10、封装Ajax

//名值对编码

function params(data) {

var arr = [];

for (var i in data) {

arr.push(encodeURIComponent(i) + '=' + encodeURIComponent(data[i]));

}

return arr.join('&');

}

//封装Ajax

function ajax(obj) {

var xhr = new createXHR();//调用creatXHR创建XHR对象

obj.url = obj.url + '?rand=' + Math.random();//为url连接添加随机值

obj.data = params(obj.data);//调用params方法对数据进行编码处理

if (obj.method === 'get')//如果是get请求传输

//进行get请求连接的拼凑

obj.url = obj.url.indexOf('?') == -1 ? obj.url + '?' + obj.data : obj.url + '&' + obj.data;

if (obj.async === true) {//如果是异步传输

xhr.onreadystatechange = function () {//异步传输后的响应

if (xhr.readyState == 4) //正常返回数据

callback(); //调用响应函数

};

}

xhr.open(obj.method, obj.url, obj.async);//启动一个请求

if (obj.method === 'post') {//如果是post请求传输

xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');//添加头文件

xhr.send(obj.data);//发送数据

} else {

xhr.send(null);//如果不是post请求传输,发送空数据

}

if (obj.async === false) {//如果是同步传输

callback();//调用响应函数

}

//想用函数

function callback () {

if (xhr.status == 200) {//服务器成功响应

obj.success(xhr.responseText); //回调

} else {

alert('数据返回失败!状态代码:' + xhr.status + ',状态信息:' + xhr.statusText);

}

}

}

//调用 ajax

addEvent(document, 'click', function () { //IE6 需要重写 addEvent

ajax({

method : 'get',

url : 'test.jsp',

data : {

'name' : 'chen',

'age' : 22

},

success : function (text) {

alert(text);//弹出响应内容

},

async : true //异步传输

});

});

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342