Ajax的总结
主要从Ajax是什么?可以用来干什么?基本要素,优缺点,执行过程等几方面来解释。
Ajax是什么?
Ajax主要用来实现客户端与服务器端的异步通信效果,实现页面的局部刷新,早期的浏览器并不能原生支持ajax,可以使用隐藏帧(iframe)方式变相实现异步刷新,使用ajax原生发送请求主要通过XMLHttpRequest对象实现异步通信的效果。
Ajax要素
实现原生Ajax的核心就是 XMLHttpRequest
Ajax请求的重点内容:
请求方式:get/post
1、get一般用来进行查询操作,url地址有长度限制,请求的参数都暴露在url地址当中,如果传递中文参数,需要自己进行编码操作,安全性较低。
2、post请求方式主要用来提交数据,没有数据长度的限制,提交的数据内容存在于http请求体中,数据不会暴漏在url地址中。
响应内容:xhr.responseText;(重点)xhr.responseXML
原理:利用script标签向外发出请求不会被拒绝
ajax的优缺点
优点:可以使得页面不重载全部内容的情况下加载局部内容,降低数据传输量,避免用户不断刷新或者跳转页面,提高用户体验。
缺点:
1、ajax不支持浏览器back按钮。
2、安全问题 AJAX暴露了与服务器交互的细节。
3、对搜索引擎的支持比较弱。
4、破坏了程序的异常机制。
Ajax的异步刷新
iframe 在一个页面内部嵌入一个子页面
name属性表示iframe的名称,用于区分不同的iframe
iframe属性frameborder表示子页面的边框
width和height分别表示子页面的宽高
src属性表示嵌入子页面的url地址
可以通过表单的target属性指向iframe的name属性值,表示响应内容在子页面刷新
<div id="info"></div>
<form action="./inner.php" method="post" target="abc">
用户名:<input type="text" name="username">
密 码:<input type="password" name="password">
<input type="submit" value="提交">
</form>
<iframe width="0" height="0" frameborder="0" name="abc"></iframe>
<?php
$uname = $_POST['username'];
$pw = $_POST['password'];
// js中的parent表示父级页面
if($uname == 'admin' && $pw == '123'){
echo '<script> parent.document.getElementById("info").innerHTML = "登录成功";</script>';
}else{
echo '<script> parent.document.getElementById("info").innerHTML = "用户名或者密码错误";</script>';
}
?>
ajax的基本操作步骤
执行过程
// 1、创建XMLHttpRequest对象
var xhr = new XMLHttpRequest();
// 2、配置发送参数
xhr.open('get','./data.php');
// 3、执行发送动作
xhr.send(null);
// 4、处理响应
xhr.onreadystatechange = function(){
if(xhr.status == 200){
if(xhr.readyState == 4){
// 在这里才可以获取服务器返回的数据
var result = xhr.responseText;
if(result === '1'){
var info = document.getElementById('info');
info.innerHTML = '服务器数据已经返回';
}
}
}
}
封装
function myajax(type,url,param,callback){
// 1、创建xhr对象
var xhr = null;
if(window.XMLHttpRequest){
// 标准写法
xhr = new XMLHttpRequest();
}else{
// IE的写法
xhr = new ActiveXObject('Microsoft.XMLHTTP');
}
// 2、准备发送参数
if(type == 'get'){
// 处理get请求参数,并且进行编码
url += '?' + encodeURI(param);
}
xhr.open(type,url);
// 3、执行发送动作
var data = null;
if(type == 'post'){
// 如果是post提交,那么就把参数传递给send
data = param;
// post提交必须设置请求头
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
}
xhr.send(data);
// 4、处理响应(指定回调函数)
// 下面的回调函数什么时候执行?不确定的
xhr.onreadystatechange = function(){
// 判断响应的状态
if(xhr.status == 200 && xhr.readyState == 4){
// 获取响应数据
var result = xhr.responseText;
// 调用回调函数
callback(result);
}
}
}