(注:本章讲解涉及部分后端知识,将以php提供数据的方式进行相应的demo实现)
全称:AsynchronousJavascriptAndXml
AJAX不是一种新的编程语言,而是一种用于创建更快更好以及交互性更强的WEB应用程序技术,该技术在98年前后得到了应用。通过AJAX,你的JS可以通过JS的XMLHttpRequest对象在页面不重载的情况下与服务器直接进行通信。这样可以在服务器请求到想要的数据,而不是整个页面。AJAX的核心就是JS的XMLHttpRequest对象。xhr对象是在IE5中首次引入,它是一种支持异步请求的对象。
1.创建XMLHttpRequest对象。
所有现代浏览器(IE7+,chrome,firefox,opera,safari)均内建XMLHttpRequest对象。但是IE5、6使用ActiveXObject对象。
open方法:创建新的HTTP请求,并指定此请求的方法,URL以及验证信息。
xhr.open(type,url,async,user,password);
type:HTTP请求方式,GET、POST等。大小写不敏感。
url:请求地址。(get请求如果有传值直接以urlparam=value的方式传递。post的方式直接在发送指令的时候传递)
async:布尔型,请求是否为异步方式。默认为true。如果为真,当状态改变时会调用onreadystatechange属性指定的回调函数。(可选)
注释:当您使用async=false时,请不要编写onreadystatechange函数-把代码放到send()语句后面即可:
password:验证信息中的密码部分,如果用户名为空,则此值将会被忽略。(少用仅了解)
注:在AJAX中,其实我们就是来模拟正常的表单提交数据。正常的表单在POST数据时,会发送Content-Type字段,所以我们在AJAX中就要指定该字段值为application/x-www-form-urlencoded。并且对字段名称和值进行编码处理在发送。使用setRequestHeader:单独指定请求的某个HTTP头。
注:一些特殊字符可能与代码中的字符冲突(如URL中分隔符&等等),故数据应使用encocdeURIComponent()函数进行编码。
3.发送指令。
send():发送请求到HTTP服务器并接收回应。
此方法的同步或异步方式取决于open方法中的async参数,如果async为true,此方法将立即返回,如果为false,此方法将会等待请求完成或者超时时才会返回。
xhr.send(body);
body:通过此请求发送的数据。GET请求设置为null即可。
post和get方式实现ajax的不同之处
5.客户端接收。
6.释放XMLHttpRequest对象。
通过onreadystatechange属性指定readystate属性改变时的事件处理回调函数。
xhr.onreadystatechange=function(){}
readyState属性:返回请求的当前状态。
status属性:返回当前请求的状态码。
statusText属性:返回当前请求的响应行信息。
responseXML属性:将响应信息格式化为XMLDocument对象返回。
responseText属性:将响应信息作为字符串返回。
JSON:JavascriptObjectNotation,一种轻量级的基于文本的数据交换格式,易于人阅读和编写,也能提高网络传输速率。
ES5新增的两个方法:
JSON.parse:将JSON字符串数据转换为JSON对象。
JSON.stringify:将JSON对象转换为JSON字符串。
注:1、浏览器支持:IE8+。
2、JSON格式的字符串里面的key或者字符串型的value都必须用双引号包裹
html页面
demo通过封装的ajax实现加载更多的功能以及通过事件源对象删除单条数据(本来打算将源码托管到GitHub,账号丢失)
*文件夹目录
1.html页面
@charset"utf-8";/*CSSDocument*/*{margin:0;padding:0;}body{background:#7CCD7C;}.box{width:80%;margin:0auto;}.newsTitle{font-size:24px;text-align:center;margin:0auto;padding:20px10px;font-weight:normal;letter-spacing:10px;}.newsList{display:block;margin:0auto;line-height:50px;font-size:16px;list-style:none;}.newsListli{padding:020px;box-shadow:0010px#eeeeee;}.box.newsListli:hover{background:#B0E2FF;}.newsListli:nth-child(odd){background:#f3f3f3;}.newsListli:nth-child(even){background:#eeeeee;}.deleteBtn{float:right;text-decoration:none;font-size:16px;color:#555555;}.loadMoreInfo{margin-top:10px;text-align:center;line-height:50px;font-size:16px;background:#ffffff;cursor:pointer;vertical-align:middle;margin-bottom:20px;}.loadMoreInfoimg{display:none;width:20px;height:20px;vertical-align:middle;}ajax.css3.公共js(封装的$函数以及ajax函数)
在使用ajax异步调用的时候,可能碰到同时调用多个ajax的情况,而且多个ajax之间还存在依赖关系。 引用回调函数的嵌套说明ajax的以来调用: