什么是ajax

1.背景介绍
什么是AJAX?

即异步的 JavaScript 和 XML,是一种用于创建快速动态网页的技术;

传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。

使用AJAX则不需要加载更新整个网页,实现部分内容更新

2.知识剖析
AJAX

1、什么是ajax

2、常见的ajax使用场景

3、为什么需要使用ajax

4、Ajax的工作原理

5、XMLHttpRequest常用方法及属性

6、几种常见的写法

1、什么是ajax

AJAX

AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。

AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。

2、常见的ajax使用场景

谷歌地图,甚至一些弹幕,微博的时时更新评论等等

3、为什么需要使用ajax

ajax主要是实现页面和web服务器之间数据的异步传输。

简单来说,不采用ajax的页面,当用户在页面发起请求时,就要进行整个页面的刷新,刷新快慢取决于服务器的处理快慢。在这个过程中用户必须得等待,不能进行其他操作。也就是同步的方式。客户端和服务端传递了很多不需要的数据。效率低,用户体验差。

a、采用ajax的页面,可以实现页面的局部更新,而不是整个页面的更新;b、并且发起请求后,用户还可以进行页面上的其他操作。这就是异步的方式。c、客户端和服务端间只传递需要的数据,效率高,用户体验性好。d、并且Ajax引擎在客户端运行,承担了一部分本来由服务器承担的工作,从而减少了大用户量下的服务器负载。

4、Ajax的工作原理

图片里面提到一个xhr,所谓的“XHR”(浏览器内置对象”XMLHttpRequest”),也就是Ajax功能实现所依赖的对象,AJAX就是通过浏览器的内置对象XHMHttpResquest来发送异步请求的,异步请求不会妨碍客户端的任何操作。

异步:

XHR相当于是一个通信兵,来负责客户端与服务器之间的通信传输。举个栗子:

要打仗了,前方阵地(客服端)不可能只等着通信兵(XHR)传递消息其他什么也不干吧,所以前方阵地还在干着自己的事情然后派通信兵去请求后方指挥部(服务器)的命令,指挥部下达命令指挥,通信兵再把命令传到前方阵地,然后前方阵地再执行命令相关的操作(客户端把数据渲染到页面),这也就是Ajax的异步原理。

再来说说同步:

所谓的同步就是前方阵地和通信兵一起去向服务器请求数据,直到通信兵请求到数据,我才开始渲染页面,在请求的过程中页面一直是白屏等待的。

5、XMLHttpRequest常用方法

一、open();

XMLHttpRequest.open()方法用于指定 HTTP 请求的参数,或者说初始化 XMLHttpRequest 实例对象。它一共可以接受五个参数。

例:

xhr.open(‘POST’, ‘/carrots-admin-ajax/a/login’, true);

参数:

a, method:用于指定请求的类型  “GET"或者"POST”

b, url:用于请求的地址, 可相对可绝对

c, asyncFlag:指定请求方式为同步还是异步, true为异步, false为同步

二、send();

XMLHttpRequest.send()方法用于实际发出 HTTP 请求。它的参数是可选的,如果不带参数,就表示 HTTP 请求只包含头信息,也就是只有一个 URL,典型例子就是 GET

请求;如果带有参数,就表示除了头信息,还带有包含具体数据的信息体,典型例子就是 POST 请求。

var xhr = new XMLHttpRequest();

var data = ‘name=’ + userVal + ‘&pwd=’ + pwVal;

xhr.open(‘POST’, ‘/carrots-admin-ajax/a/login’, true);

/* POST的请求头 */

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

/* 发出HTTP请求 */

xhr.send(data);

注意,所有 XMLHttpRequest 的监听事件,都必须在send()方法调用之前设定。(send放在最后)

6、XMLHttpRequest常用属性

一, readyState

XMLHttpRequest.readyState返回一个整数,表示实例对象的当前状态。该属性只读。它可能返回以下值。

0,表示 XMLHttpRequest 实例已经生成,但是实例的open()方法还没有被调用。

1,表示open()方法已经调用,但是实例的send()方法还没有调用,仍然可以使用实例的setRequestHeader()方法,设定 HTTP 请求的头信息。

2,表示实例的send()方法已经调用,并且服务器返回的头信息和状态码已经收到。

3,表示正在接收服务器传来的数据体(body 部分)。

4,表示服务器返回的数据已经完全接收,或者本次接收已经失败。

二, onreadystatechange

XMLHttpRequest.onreadystatechange属性指向一个监听函数。

通信过程中,每当实例对象发生状态变化,它的readyState属性的值就会改变。这个值每一次变化,都会触发readyStateChange事件。

readystatechange事件发生时(实例的readyState属性变化),就会执行这个属性。

另外,如果使用实例的abort()方法,终止 XMLHttpRequest

请求,也会造成readyState属性变化,导致调用XMLHttpRequest.onreadystatechange属性。

var xhr = new XMLHttpRequest();

xhr.onreadystatechange = function(){

// 通信成功时,状态值为4

if (xhr.readyState === 4){

if (xhr.status === 200){

console.log(xhr.responseText);

} else {

console.error(xhr.statusText);

}

}};

xhr.open(‘GET’, ‘/endpoint’, true);

xhr.send(null);

三, responseText

XMLHttpRequest.responseText属性返回从服务器接收到的字符串,该属性为只读。只有 HTTP 请求完成接收以后,该属性才会包含完整的数据

四, status

XMLHttpRequest.status属性返回一个整数,表示服务器回应的 HTTP

状态码。一般来说,如果通信成功的话,这个状态码是200;如果服务器没有返回状态码,那么这个属性默认是200。请求发出之前,该属性为0。该属性只读。

200, OK,访问正常

404, Not Found,未发现指定网址

500, Internal Server Error,服务器发生错误

基本上,只有2xx和304的状态码,表示服务器返回是正常状态。

7、常见几种ajax方法

结合任务来看三种常见的写法(不涉及框架中写法)

a、原生写法:见demo

b、jQuery 底层 AJAX 实现:见demo

c、jQuery 高层 AJAX 实现:见demo

3.常见问题
1、跨域问题

2、使用post提交的时候需要设置content-type为"application/x-www-form-urlencoded"

4.解决方案
1、nginx配置跨域

2、使用post提交的时候需要设置content-type会出错,见demo

5.编码实战

原生写法/* 创建实例 */

//         var xhr = new XMLHttpRequest();

//         /* 需要发送的数据 */

//         var data = ‘name=’ + userVal + ‘&pwd=’ + pwVal;

//         console.log(data)

//         /* 指定请求的参数 */

//         xhr.open(‘POST’, ‘/carrots-admin-ajax/a/login’, true);

//         /* POST的请求头 */

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

//         /* 发出HTTP请求 */

//         xhr.send(data);

/* $.ajax()写法 */

// var xhr = $.ajax({

//     type: ‘POST’,

//     data: {

//         name: userVal,

//         pwd: pwVal

//     },

//     url: ‘/carrots-admin-ajax/a/login’,

//     success: function () {

//       }

// });

/* $.post()写法 */

var data = {

name: userVal,

pwd: pwVal,

}

console.log(data)

var xhr = $.post(’/carrots-admin-ajax/a/login’, data, function () {})

6.扩展思考
AJAX的优缺点?

ajax的缺点:

ajax不支持浏览器back按钮。

安全问题 AJAX暴露了与服务器交互的细节。

对搜索引擎的支持比较弱。

破坏了程序的异常机制。

不容易调试。

get与post的区别?

GET - 从指定的资源请求数据。

POST - 向指定的资源提交要被处理的数据

GET 请求可被缓存

GET 请求保留在浏览器历史记录中

GET 请求可被收藏为书签

GET 请求不应在处理敏感数据时使用

GET 请求有长度限制

GET 请求只应当用于取回数据

POST 请求不会被缓存

POST 请求不会保留在浏览器历史记录中

POST 不能被收藏为书签

POST 请求对数据长度没有要求

作者:jnshu_it
来源:CSDN
原文:https://blog.csdn.net/jnshu_it/article/details/83858684
版权声明:本文为博主原创文章,转载请附上博文链接!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章