视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Ajax怎样实现网页异步更新
2020-11-27 15:26:05 责编:小采
文档


这次给大家带来Ajax怎样实现网页异步更新,Ajax实现网页异步更新的注意事项有哪些,下面就是实战案例,一起来看一下。

1:ajax的概念

全称:Asynchronous Javascript And Xml

AJAX不是一种新的编程语言,而是一种用于创建更快更好以及交互性更强的WEB应用程序技术,该技术在98年前后得到了应用。通过AJAX,你的JS可以通过JS的XMLHttpRequest对象在页面不重载的情况下与服务器直接进行通信。这样可以在服务器请求到想要的数据,而不是整个页面。AJAX的核心就是JS的XMLHttpRequest对象。xhr对象是在IE5中首次引入,它是一种支持异步请求的对象。

2:ajax的优势

无刷新更新数据。

异步与服务器通信。

基于标准被广泛支持。

前端与后端分离。

节省带宽。

3:编写步骤

1.创建XMLHttpRequest对象。

所有现代浏览器(IE7+,chrome,firefox,opera,safari)均内建XMLHttpRequest对象。但是IE5、6使用ActiveXObject对象。

function getAjax() {
var xmlhttp = null;
if(window.ActiveXObject){
 xmlhttp = new ActiveXObject(’Microsoft.XMLHTTP’);
} else if(window.XMLHttpRequest){
 xmlhttp = new XMLHttpRequest();
}
return xmlhttp;
}

2.打开与Server的连接,指定发送方式、URL以及权限等。

open方法:创建新的HTTP请求,并指定此请求的方法,URL以及验证信息。

xhr.open(type, url, async, user, password);

type:HTTP请求方式,GET、POST等。大小写不敏感。

url:请求地址。

async:布尔型,请求是否为异步方式。默认为true。如果为真,当状态改变时会调用onreadystatechange属性指定的回调函数。(可选)

user:如果服务器需要验证,此处指定用户名,如果未指定,当服务器需要验证时,会弹出验证窗口。(少用仅了解)

password:验证信息中的密码部分,如果用户名为空,则此值将会被忽略。(少用仅了解)

注:

在AJAX中,其实我们就是来模拟正常的表单提交数据。正常的表单在POST数据时,会发送Content-Type字段,所以我们在AJAX中就要指定该字段值为application/x-www-form-urlencoded。并且对字段名称和值进行编码处理在发送。使用setRequestHeader:单独指定请求的某个HTTP头。

注:数据应使用encocdeURIComponent()函数进行编码。

3.发送指令。

send():发送请求到HTTP服务器并接收回应。

此方法的同步或异步方式取决于open方法中的async参数,如果async为true,此方法将立即返回,如果为false,此方法将会等待请求完成或者超时时才会返回。

xhr.send(body);

body:通过此请求发送的数据。GET请求设置为null即可。

4.等待并接收服务器返回的处理结果。

5.客户端接收。

6.释放XMLHttpRequest对象。

4:回调函数

通过onreadystatechange属性指定readystate属性改变时的事件处理回调函数。

xhr.onreadystatechange = function(){}

readyState属性:返回请求的当前状态。

状态:

0:对象已建立,尚未初始化(未调用open方法)。

1:对象已建立,尚未调用send方法。

2:send方法已调用。但是当前的状态以及HTTP状态未知。

3:开始接收数据,因为响应以及HTTP头不全,这时通过responseBody和responseText获取部分数据会出现错误。

4:数据接收完毕,此时可以通过responseBody和responseText获取完整的响应数据。

status属性:返回当前请求的状态码。

200 OK:请求文档已经找到,并正确返回。

304 Not Modified:拥有一个本地的缓存副本,服务器端内容与此相同。

403 Forbidden:请求者对所请求的文档不具有相应的权限。

404 Not Found:请求的文档没找到。

statusText属性:返回当前请求的响应行信息。

responseXML属性:将响应信息格式化为XML Document对象返回。

responseText属性:将响应信息作为字符串返回。

5:JS解析JSON

JSON简介:(js文章中有提到)

定义:Javascript Object Notation,一种轻量级的基于文本的数据交换格式,易于人阅读和编写,也能提高网络传输速率。

ES5新增的两个方法:

JSON.parse:将JSON字符串数据转换为JSON对象。

JSON.stringify:将JSON对象转换为JSON字符串。

注:1、浏览器支持:IE8+。

  2、JSON格式的字符串里面的key或者字符串型的value都必须用双引号包裹。

6:局部数据刷新

操作相应的DOM节点(例如评论列表的分页效果)

7:事件委托的应用

事件委托:利用冒泡机制,将子元素事件委托给父元素执行(例如某些新闻网站有去除部分用户不喜好的新闻)

8:前后端分离

后台只管数据输出和业务逻辑处理,前端负责交互逻辑和界面展示。简单的说:前端静态页面中没有有后台程序代码,后台输出不带有HTML标签的数据。

前后端分离靠ajax来实现数据的交互。(函数分装实现具体的分离,demo中给出)

相信看了这些案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

相关阅读:

如何解决layer.photos()异步修改图片地址后显示异常的问题

下载本文
显示全文
专题