什么是AJAX?

大家好,我是IT修真院深圳分院第4期学员梁耀,一枚正直纯洁善良的web程序员。

今天给大家分享:

【JS-01】函数表达式和函数声明有什么区别?

Web小课堂

分享人:梁耀

1.背景介绍

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

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

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

这里先说说什么是同步异步,

我们知道JS是单线程的,只有在一个任务处理完成的时候才会执行下一个任务;任务队列

单线程影响效率,所以把任务分成同步任务和异步任务,同步任务即主线程上排队执行的任务;

异步任务是不进入主线程进入任务队列的任务,只有"任务队列"通知主线程,某个异步任务可以执行了,该任务才会进入主线程执行

2.知识剖析

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

1.创建AJAX对象

2.发出HTTP请求

3.接收服务器传回的数据

4.更新网页数据

JAX-创建XMLHttpRequest对象

XMLHttpRequest 用于在后台与服务器交换数据。

为了应对所有的现代浏览器,包括 IE5 和 IE6,请检查浏览器是否支持 XMLHttpRequest 对象。如果支持,则创建 XMLHttpRequest 对象。如果不支持,则创建 ActiveXObject

这里值得注意的是,AJAX只能向同源网址(协议、域名、端口都相同)发出HTTP请求,

如果要跨域将会报错。

AJAX-向服务器发送请求

如需将请求发送到服务器,我们使用 XMLHttpRequest 对象的 open() 和 send() 方法:

xmlhttp.open("GET","ajax_info.txt",true);

xmlhttp.send();

3.常见问题

1. 缓存问题

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

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

就是在请求的后面 加上时间戳或是随机数,让url变成唯一,或者是,改成post请求。

2.Ajax乱码问题

乱码问题虽然我们目前遇到的不多,但是也属于比较常见的一个问题了。出现的主要原因就是编码不一致导致的。

如果出现乱码问题了,首先检查一下meta声明的charset要和请求的页面返回的charset一致。response.charset="gb2312 or utf-8"

3.Ajax状态0的问题

有时候在测试Ajax代码的时候加了 xhr.status==200的判断后,一直不执行xhr.status==200的代码,

这个就需要注意了。xhr.status==200是要通过服务器确认后来返回的,在服务器页面没有发生错误或者转向时才返回200状态的,

此状态和你通过浏览器访问页面时服务器定义的状态一致。直接拖进浏览器浏览结果或者双击运行html页面的,未发生错误时,此时的xhr.status是0,不是200

4.拓展思考

ajax的优点:

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

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

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

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

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

ajax的缺点:

ajax不支持浏览器back按钮。

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

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

破坏了程序的异常机制。

不容易调试。

post请求与get请求

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

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

GET 请求可被缓存

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

GET 请求可被收藏为书签

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

GET 请求有长度限制

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

POST 请求不会被缓存

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

POST 不能被收藏为书签

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

参考文献

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

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

更多讨论

AJAX适用场景有哪些?

表单驱动的交互

深层次的树的导航

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

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

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

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


1:post一般是是通过json数据的形式(可以是对象或者字符串)


2.一般有四种方式:https://www.cnblogs.com/summers/p/3225375.html


3.get与post的区别主要在于

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

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


4.局部更新,不需要重新加载整个页面,提高用户体验度


5.表单驱动的交互

深层次的树的导航

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

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

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

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


今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

------------------------------------------------------------------------------------------------------------------------

技能树.IT修真院

“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。

这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧?!

你可能感兴趣的:(什么是AJAX?)