什么是ajax?

作者: 傲慢的小寒哥 | 来源:发表于2018-03-30 15:51 被阅读0次

大家好,我是IT修真院萌新分院的王寒,一枚正直,纯洁,善良的前端程序员。

今天给大家分享一下什么是ajax。

1.背景介绍

什么是AJAX?

即异步的 JavaScript 和 XML,是一种用于创建快速动态网页的技术; 传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。 使用AJAX则不需要加载更新整个网页,实现部分内容更新;

2.知识剖析

具体来说,AJAX包括以下几个步骤。

创建AJAX对象

发出HTTP请求

接收服务器传回的数据

更新网页数据

xmlhttprequest对象的用法

                xhr.open("get","ajax_info.txt",false);

                xhr.send(null);

send方法接受一个数据,即要作为请求主体的数据。如果不需要请求主体发回数据,则传回null; 收到响应后数据会填入xhr对象的属性:

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

responseXML:如果响应的内容类型是“text/xml”或者“application/xml” 这个属性中就保存包含着响应数据的XML DOM文档

status:响应的HTTP状态

statusText:HTTP状态说明

在收到响应后,第一步先确定status属性,用来确定是否返回成功(状态为200); responseText属性就准备就绪,此外,状态码304表示请求的资源没有被修改; 但一般为了确保接受到适当的响应还需要检测上面两种状态码;

                           function sendAjax() {

  //构造表单数据

  var formData = new FormData();

  formData.append('username', 'johndoe');

  formData.append('id', 123456);

  //创建xhr对象

  var xhr = new XMLHttpRequest();

  //设置xhr请求的超时时间

  xhr.timeout = 3000;

  //设置响应返回的数据格式

  xhr.responseType = "text";

  //创建一个 post 请求,采用异步

  xhr.open('POST', '/server', true);

  //注册相关事件回调处理函数

  xhr.onload = function(e) {

    if(this.status == 200||this.status == 304){

        alert(this.responseText);

    }

  };

  xhr.ontimeout = function(e) { ... };

  xhr.onerror = function(e) { ... };

  xhr.upload.onprogress = function(e) { ... };

  //发送数据

  xhr.send(formData);

}

3.常见问题

1、IE浏览器下面的缓存问题

2、跨域问题

3、Ajax乱码问题

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

5、Ajax对象属性的大小写问题

6、Ajax状态为0的问题

4.解决方法

1. 缓存问题

在IE浏览器下面使用get请求时,如果第一次请求了数据之后IE会自动缓存数据,如果下一次再发送同样的 请求的时候浏览器会自动先去找缓存显示出来,所以如果请求的数据有变化的时候,这里是看不到变化的。

解决办法:

xhr.open("get","xxxx.aspx?_dc="+new Date().getTime(),true);

就是在请求的后面 加上时间戳或是随机数,让url变成唯一,或者是,改成post请求。 (get和post请求的区别可参见浅谈HTTP中Get与Post的区别

2. 跨域问题

这是我们目前见到的最多的,也是最熟悉的一个问题。本地上面直接采用Nginx跨域实现。在服务器上实现跨域,可以通过后端达成,可参考跨域有几种处理方式?注意 Nginx跨域可以同时配置多个接口的,就是多写几个location就好了,然后location后面带的参数不一样就可以了。

乱码问题虽然我们目前遇到的不多,但是也属于比较常见的一个问题了。出现的主要原因就是编码不一致导致的。 如果出现乱码问题了,首先检查一下meta声明的charset要和请求的页面返回的charset一致。response.charset="gb2312 or utf-8"

4. 使用post提交的时候需要进行的设置 

                           content-Type: application/x-www-form-urlencoded;

                           //jQuery中,

                           content-Type: application/x-www-form-urlencoded;charset=utf-8;

                           //AngularJS中$http

                           content-Type: application/json; charset=utf-8;

                           //使用原生Ajax需要在open以后才能使用xhr.setRequestHeader()方法,否则出错

                           xhr.open("post","xxxx.aspx",true);

                           xhr.setRequestHeader("content-type","application/x-www-form-urlencoded")

                           //用原生写时必须在open()方法之后send()方法之前调用

5. Ajax对象属性的大小写问题 

有些浏览器比如火狐,对大小写是敏感的,if (xhr.readystate==4)这种写法, 在IE下是成立的,但是在Firefox下就行不通了,因为IE不区分大小写,Firefox是区分大小的。标准写法为if (xhr.readyState==4),同理还有属性 responseText,responseXML。习惯采用驼峰形式的写法可以避免这个问题。

6. Ajax状态0的问题

有时候在测试Ajax代码的时候加了 xhr.status==200的判断后,一直不执行xhr.status==200的代码, 这个就需要注意了。xhr.status==200是要通过服务器确认后来返回的,在服务器页面没有发生错误或者转向时才返回200状态的, 此状态和你通过浏览器访问页面时服务器定义的状态一致。直接拖进浏览器浏览结果或者双击运行html页面的,未发生错误时,此时的xhr.status是0,不是200。

5、编码实战

6、扩展思考

AJAX的优缺点

get与post

ajax的优点:

最大的一点是页面无刷新,用户的体验非常好。

使用异步方式与服务器通信,具有更加迅速的响应能力。

可以把以前一些服务器负担的工作转嫁到客户端,利用客户端闲置的能力来处理, 减轻服务器和带宽的负担,节约空间和宽带租用成本。并且减轻服务器的负担, ajax的原则是“按需取数据”,可以最大程度的减少冗余请求,和响应对服务器造成的负担。

基于标准化的并被广泛支持的技术,不需要下载插件或者小程序。

ajax可使因特网应用程序更小、更快,更友好。

ajax的缺点:

ajax不支持浏览器back按钮。

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

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

破坏了程序的异常机制。

不容易调试。

GET - 从指定的资源请求数据。 POST - 向指定的资源提交要被处理的数据

GET 请求可被缓存 GET 请求保留在浏览器历史记录中 GET 请求可被收藏为书签 GET 请求不应在处理敏感数据时使用 GET 请求有长度限制 GET 请求只应当用于取回数据

POST 请求不会被缓存 POST 请求不会保留在浏览器历史记录中 POST 不能被收藏为书签 POST 请求对数据长度没有要求

7、参考文献:

参考一:《JavaScript高级编程设计》

参考二:AJAX -- JavaScript 标准参考教程(alpha)——阮一峰

8、更多讨论

AJAX适用场景有哪些?

Ajax适用场景

表单驱动的交互

深层次的树的导航

快速的用户与用户间的交流响应

类似投票、yes/no等无关痛痒的场景

对数据进行过滤和操纵相关数据的场景

普通的文本输入提示和自动完成的场景

Ajax不适用场景

部分简单的表单

搜索

基本的导航

替换大量的文本

对呈现的操纵

问题:

1.常用的跨域方法有哪些?

答:请点击

2.同步请求和异步请求的区别?

答:请点击

3.ajax应用场景?

答:表单驱动的交互

深层次的树的导航

快速的用户与用户间的交流响应

类似投票、yes/no等无关痛痒的场景

对数据进行过滤和操纵相关数据的场景

普通的文本输入提示和自动完成的场景

Ajax不适用场景

部分简单的表单

搜索

基本的导航

替换大量的文本

对呈现的操纵

。。。。。。。

相关文章

  • ajax面试题

    1、什么是AJAX,为什么要使用Ajax(请谈一下你对Ajax的认识)什么是ajax:AJAX是“Asynchro...

  • 关于原生JS的AJAX

    一、什么是AJAX?以及AJAX诞生缘由 什么是AJAX? AJAX全称是异步JS和XML(Asynchronou...

  • 前端面试,AJAX知识

    1、什么是AJAX,为什么要使用Ajax? AJAX是“Asynchronous JavaScript and X...

  • AJAX总结

    1.什么是ajax,为什么要使用ajax?ajax是“Asynchronous JavaScript and XM...

  • JavaScript进阶知识点--AJAX及JSON

    AJAX 关于 AJAX 什么是 AJAX AJAX 的全称是 Asynchronous JavaScript a...

  • ajax面试题

    1.什么是AJAX,为什么要使用Ajax(请谈一下你对Ajax的认识) AJAX是“Asynchronous Ja...

  • 进阶任务-12

    ajax 是什么?有什么作用? 1. 什么是ajax AJAX 的全称为 Asynchronous JavaScr...

  • AJAX

    一、简介 AJAX菜鸟教程 什么是 AJAX ? AJAX = 异步 JavaScript 和 XML。 AJAX...

  • JQuery学习总结(二)AJAX技术

    一、AJAX简介 什么是 AJAX ?AJAX = 异步 JavaScript 和 XML。AJAX 是一种用于创...

  • 面试题汇集

    ajax常见面试题 1:什么是ajax?ajax作用是什么?异步的javascript和xml AJAX 是一种...

网友评论

    本文标题:什么是ajax?

    本文链接:https://www.haomeiwen.com/subject/aaeicftx.html