Ajax 的简介与使用
一、什么是Ajax
Ajax 的全称是 Asynchronous JavaScript and XML(即异步的 JavaScript 和 XML),是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术
二、Ajax的优缺点
1、优点:
- 通过异步模式,提升了用户体验
- 优化了浏览器和服务器之间的传输,减少不必要的数据往返,减少了带宽占用
- Ajax 引擎在客户端运行,承担了一部分本来由服务器承担的工作,从而减少了大用户量下的服务器负载
2、缺点
- 不支持浏览器back按钮
- 安全问题,Ajax 暴露了与服务器交互的细节
- 对搜索引擎的支持比较弱
三、Ajax 的使用 -- 实现步骤
1、创建 XMLHttpRequest 对象,即创建一个异步调用对象
var XHR;
if(window.XMLHttpRequest){
XHR=new XMLHttpRequest(); //IE7+, Firefox, Chrome, Opera, Safari...
}else{
XHR=new ActiveXObject("Microsoft.XMLHTTP"); //IE6,IE5
2、创建一个新的 HTTP 请求,并指定该 HTTP 请求的方法、URL 及验证信息
XHR.open(method,url,async);
// method:请求类型,GET 或 POST---------可选
// url:文件在服务器上的位置--------------必要参数
// async:true(异步)或 false(同步)----可选
// 以上参数使用时均要加上“”
3、设置响应 HTTP 请求状态变化的函数
XHR.onreadystatechange = function () {
//异步调用成功
if (XHR.readyState === 4) {
if ((XHR.status >= 200 && XHR.status < 300) || XHR.status === 304) {
//获得服务器返回的数据
data = JSON.parse(XHR.responseText);
// 渲染数据
renderDataToDom();
} else {
console.log('unsuccess');
}
}
};
4、发送 HTTP 请求
request.send();
5、获取异步调用返回的数据 (JSON)
6、使用 JavaScript 和 DOM 实现局部刷新
四、Ajax中的一些处理总结
1、服务器响应处理
- responseText:获得字符串形式的响应数据
- responseXML:获得XML 形式的响应数据
2、同步处理
XHR.open("GET","demo_get.html",false);
XHR.send(); // 直接在 send() 后面处理返回来的数据
document.getElementById("target").innerHTML=XHR.responseText;
3、异步处理
异步处理相对比较麻烦,要在请求状态改变事件中处理
XHR.onreadystatechange=function(){ //接收到服务端响应时触发
if(XHR.readyState==4&&XHR.status==200){
document.getElementById("target").innerHTML=XHR.responseText;
}
}
下面是 XMLHttpRequest 对象的三个重要的属性
- onreadystatechange:存储函数,每当 readyState 属性改变时,就会调用该函数
- readyState:存有 XMLHttpRequest 的状态
0:请求未初始化
1:服务器连接已建立
2:请求已接收
3:请求处理中
4:请求已完成,且响应已就绪
- XHR.status:表示响应状态码。比较常见的有:
200:“OK”(当 readyState 等于 4 且状态为 200 时,表示响应已就绪)
304:该资源在上次请求之后没有任何修改(这通常用于浏览器的缓存机制,使用GET请求时尤其需要注意)
403:(禁止) 服务器拒绝请求
404:(未找到) 服务器找不到请求的网页
408:(请求超时) 服务器等候请求时发生超时
500:(服务器内部错误) 服务器遇到错误,无法完成请求
Ajax 的简介与使用的更多相关文章
- AJAX(一)AJAX的简介和基础
本节简介(异步链接服务器对象)XMLHTTPRequest以及AJAX的简介. AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML). AJ ...
- 掌握 Ajax,第 1 部分: Ajax 入门简介
转:http://www.ibm.com/developerworks/cn/xml/wa-ajaxintro1.html 掌握 Ajax,第 1 部分: Ajax 入门简介 理解 Ajax 及其工作 ...
- jQuery的AJAX方法简介及与其他文件$符号冲突的解决办法
一.重要的jQuery AJAX方法简介 $.load(url) 从服务器载入数据 $.get(url,callback) 从服务器请求数据,并执行回调函数 $.post(url,data,callb ...
- ZK框架笔记1、ZK Ajax框架简介
简介 ZK是一个基于事件驱动和组件的框架,他为web应用提供了丰富的接口.zk包括一个基于Ajax的事件驱动引擎.一整套丰富的XML用户接口语言(XML User Interface Langu ...
- Ajax(简介、基础操作、计算器,登录验证)
Ajax简介 Ajax 即"Asynchronous Javascript And XML"(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术. ...
- AJAX的简介
AJAX 指异步JavaScript及XML(Asynchronous JavaScript And XML(异步JavaScript和XML)),是指一种创建交互式网页应用的网页开发技术. 国内通常 ...
- AJAX技术简介
AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术. 您应当具备的基础知识 在继续学习之前,您需要对下面的知识有基本的了解: HTML / XHTML CSS JavaScript ...
- ajax入门简介
ajax的实现原理 ajax的定义是 Asynchronous JavaScript and XML(异步的 JavaScript 和 XML).它可以在不刷新页面的情况下提交请求与服务器进行交互动作 ...
- Ajax 用法简介
使用Ajax实现页面的局部刷新 一.不依赖jquery时是这样的用法: var xhr=new XMLHttpRequest(); xhr.onreadystatechange=function(ev ...
随机推荐
- IE6利用iframe遮挡 弹层 select
ie6的老bug了,select老是会挡住 弹层里的内容. 解决办法:(box需要设置高度) <div class="box"> <!--[if IE 6]> ...
- Tools - 在线编译环境和工具汇总
菜鸟教程 https://www.runoob.com/ 支持语言种类丰富,无需注册,包含教程.笔记.手册等内容. 菜鸟在线工具:https://c.runoob.com/ 菜鸟在线编译器:https ...
- Docker 基础操作指南
Docker 基础操作指南 拉取基础镜像: docker pull centos:latest 根据基础的Centos镜像运行一个名为base-centos的容器 docker run --name ...
- 如何愉悦使用mybatis
mybatis-generator+plugins 单独的generator是免不了全部人工的,配上各种插件则不然,感谢项目 itfsw/mybatis-generator-plugin 使用如下: ...
- Django_图片的上传下载显示配置
图片上传的配置 image = models.ImageField(upload_to='org/%Y/%m',...) upload_to默认是上传到项目的'MEDIA_ROOT/org/%Y/%m ...
- Span复习
Span复习 using System; namespace Span复习 { class Program { static void Main(string[] args) { //Console. ...
- Java网络编程探究|乐字节
大家好,我是乐字节小乐,上次给大家讲述了Java中的IO流之输出流|乐字节,本文将会给大家讲述网络编程. 主要内容如下: 网络 网络分层 IP位置 端口port 网络编程 一. 网络 1.概念 网络即 ...
- [转帖]AWS第一,「3A格局」稳固,活跃IP是如何被全球云厂商瓜分的?
AWS第一,「3A格局」稳固,活跃IP是如何被全球云厂商瓜分的? 本文作者:王刚 2019-02-24 10:42 https://www.leiphone.com/news/201902/qsz3c ...
- Asp.Net Core中创建多DbContext并迁移到数据库
在我们的项目中我们有时候需要在我们的项目中创建DbContext,而且这些DbContext之间有明显的界限,比如系统中两个DbContext一个是和整个数据库的权限相关的内容而另外一个DbConte ...
- 公钥、私钥、数字签名、数字证书、对称与非对称算法、HTTPS
作者: yoyoso https://my.oschina.net/ioslighter/blog/359207 对公钥和私钥有点稀里糊涂的,搜索了一些资料,作一些整理吧,先看这个: 加密--公钥 看 ...