初步认识ajax(个人整理)
通过使用ajax可以实现页面的部分动态化
ajax可以发送一个请求去服务端,而服务端则发送回一小段数据给客户端,这样就可以避免加载整个页面,因为很多时候页面只需要刷新某一部分的数据,而其他大部分体就不需要更新
ajax我用过的经验有两种,一种是js的ajax方法,一个是经过jQurey封装好的ajax方法,我想没有第三种吧。。
js的ajax使用流程:创建XMLHttpRequest对象 -> 对象向服务器进行请求 -> 服务器进行响应 ->客户端判断服务器的响应是否就绪
第一步:创建XMLHttpRequest对象
HXR = new XMLHttpRequest();
然而上面并不适用于IE5 和 IE6,所以对于这种浏览器需要用ActiveX 对象
HXR = new ActiveXObject("Microsoft.XMLHTTP");
因此我们在写第一步的时候可以先进行一下判断,判断是什么浏览,然后再进行对象的新建
var HXR;
if(window.XMLHttpRequest){
HXR = new XMLHttpRequest();//IE7或以上的主流浏览器
}
else{
HXR = new ActiveXObject("Microsoft.XMLHTTP");//IE5或6
}
第二步:发出请求
我们可以使用对象的open()和send()方法。
open(method,url,async)是规定请求类型(get,post),服务器的url,同步或者异步。
send(string)方法是放送请求,里面的参数只有方法是post才用到,因为get方法的请求参数已经在url里面了
方法 | 描述 |
---|---|
open(method,url,async) |
规定请求的类型、URL 以及是否异步处理请求。
|
send(string) |
将请求发送到服务器。
|
get请求使用例子:
HXR.open('GET','server.php?name=sbb&id=1',true);
HXR.send();
POST请求使用例子,如果需要添加请求信息,则要加入http表头
HXR.open('POST','server.php',true);
HXR.setRequestHeader("Content-type","application/x-www-form-urlencoded");
HXR.send("name=sbb&id=1");
第三步:服务器进行相应
这个则需要自己进行编写,可以对传过来的数据进行判断而输出对应的数据,这里就不详细写了,写个简单例子
$data = $_REQUEST['name'];
echo $data;
第四步:判断响应
请求发送到服务器之后,XMLHttpRequest 对象里的readyState 属性的改变的触发对象的onreadystatechange 事件
XMLHttpRequest 有三个重要属性readyState,status,onreadystatechange,
个人理解readyState是针对网页和服务端的连接,而进行的状态判断
status是针对服务端的判断,其中返回的数字是HTTP状态码,
当readyState改变就会触发onreadystatechange()事件
属性 | 描述 |
---|---|
onreadystatechange | 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。 |
readyState |
存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。
|
status |
200: "OK" 404: 未找到页面 |
综上所述,如果onreadystatechange一触发,就会对两个状态码进行判断,如果符合,则表明响应就绪
HXR.onreadystatechange=function()
{
if (HXR.readyState==4 && HXR.status==200)
{
alert('响应就绪');
}
}
响应就绪后,就要获取数据
可以使用根据数据使用XMLHttpRequest 对象的 responseText 或 responseXML 属性
属性 | 描述 |
---|---|
responseText | 获得字符串形式的响应数据。 |
responseXML | 获得 XML 形式的响应数据。 |
document.getElementById('sbb').innerHTML = HXR.responseText
本人写的实例:
var HXR;
if(window.XMLHttpRequest){
HXR = new XMLHttpRequest();//IE7或以上的主流浏览器
}
else{
HXR = new ActiveXObject("Microsoft.XMLHTTP");//IE5或6
}
HXR.open("GET","server.php?number="document.getElementById("search").value);
HXR.send();
HXR.onreadystatechange = function(){
if(HXR.status==200 && HXR.readyState===4){
document.getElementById('sbb').value = HXR.responseText;
}
}
初步认识ajax(个人整理)的更多相关文章
- Ajax学习整理
什么是ajax?W3School中给ajax的定义是: 1.AJAX = 异步 JavaScript 和 XML. 2.AJAX 是一种用于创建快速动态网页的技术. 3.通过在后台与服务器进行少量数据 ...
- ajax知识整理
HTTP服务 1.服务器 服务器类型 服务类型:文件服务器.数据库服务器.邮件服务器.Web服务器等: 操作系统:Linux服务器.Windows服务器等: 应用软件:Apache服务器.Nginx ...
- 数据交互 ajax代码整理
请求列表通用 /** **加载对应的试卷套题 ** */ function loadQuestions(){ var businessSubClass = { pageNo:pageNo, pageS ...
- ajax-jquery方法-初步入门01(整理)
-----------------------------------2017.07.21写----------------------------------------- 相比较原生javascr ...
- ajax-javascript原生-初步入门01(整理)
-----------------------------------2017.07.21写----------------------------------------- 1.ajax的原名: a ...
- AJAX笔记整理
AJAX: Asynchronous JavaScript and XML,异步的Javascirpt和Xml. Asynchronous:异步 与之对应的是 synchronous:同步,我们要知道 ...
- ajax代码整理
$.ajax({ type: "post", [以POST或GET的方式请求.默认GET.PUT和DELETE也可以用,有的浏览器不支持] url: url, [请求的目的地址,须 ...
- Ajax学习整理笔记
AJAX技术的出现使得javascript技术大火.不懂AJAX的同学百度一下,了解AJAX能做什么就可以了. 代码: <!DOCTYPE html> <html> <h ...
- ajax技术整理总结(1)
1.创建ajax对象 var xhr=new XMLHttpRequest(); 4.监听状态信息 xhr.onreadystatechange=function(){ //4接收完毕 ){ docu ...
随机推荐
- 一次Mutex死锁的原因探究
1.现象 最近项目中调出一个bug,某些时候程序会卡死不动,用windbg进行加载后用 ~*kb 命令列出所有的线程栈调用,发现有多个线程调用 WaitForMultipleObjects 在等 ...
- HDU1502/Luogu1352/UVa1220 party[树形DP]
题目描述 某大学有N个职员,编号为1~N.他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数Ri, ...
- flexslider.js和waypoints.js一起用时的巨坑
Flexslider has a callback API where you can execute functions after various actions:https://github.c ...
- $(window).load(function() {})和$(document).ready(function(){})的区别
JavaScript 中的以下代码 : Window.onload = function (){// 代码 } 等价于 Jquery 代码如下: $(window).load(function ( ...
- S2结业考试的第一次测验
错题分析: 1:java中的错误处理是通过异常处理模型来实现的,那么异常处理模块能处理的错误是: A:运行时错误 B:逻辑错误 C:语法错误 D:内部错误 正确答案是:A 解析:运行时异常都是Runt ...
- java 22 - 5 多线程之获取和设置线程对象的名称
如何获取线程对象的名称呢? public final String getName():获取线程的名称.如何设置线程对象的名称呢? public final void setName(String n ...
- 斗地主(Noip2015Day1T3)
题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3<4< ...
- 持久化存储——偏好设置,plist,归档---学习笔记二
//一. 本地持久化 //1.沙盒 //1.1 应用程序包:存放的是应用程序的源文件,包括资源文件和可执行文件 NSString *path = [[NSBundle mainBundle]bundl ...
- ACA烤箱菜单各项温度
说明书找不到了, 网上找到的各项温度说明, 记一个备用 casserole 218度 cake 171度 backery 177度 frozen food 238度 patato 232度 roast ...
- HP “云图”GPU虚拟化工作站解决方案
HP PCS ”云图”GPU虚拟化工作站解决方案 ——将图形计算从桌面移到数据中心 惠普云图形GPU虚拟化桌面系统是以用户为中心的私有云服务.除了保留了传统桌面虚拟化方案以集中设备为中心统一管理等优点 ...