Ajax的用法
1 Ajax是什么
1.1 Asynchronous JavaScript and XML(异步的javascript和xml)
实质为:使用浏览器内置的一个对象(XmlHttpRequest)向服务器发送请求,服务器返回xml数据或文本数据给浏览器,然后在浏览器端,使用这些数据更新部分页面,在整个过程中,页面无任何刷新。
1.2 传统的等待—响应—等待
在传统的web应用中,比如注册,用户填写整个注册表单后提交,此时浏览器会将整个注册页面抛弃,等待服务器返回一个新的完整的页面。在等待过程中,用户不能够做其他操作。服务器生成新的页面发送给浏览器,浏览器需要重新解析这个页面生成相应的页面。
1.3 图示

① Ajax引擎(即XmlHttpRequest对象),首先为该对象注册一个监听器(该监听器是一个事件处理函数,对状态改变事件(readyStatechange)进行监听)
② 当用户对GUI做了某种操作(将产生对应的事件,如焦点失去事件等)
③ 一旦产生对应的事件,将触发事件处理代码
④ 在执行事件处理代码时,会调用Ajax引擎(XmlHttpRequest对象)
⑤ 发送请求:Ajax引擎被调用后,将独自向服务器发送请求(独立于浏览器之外)
继续其他操作:在Ajax引擎发送请求的同时,用户在浏览器还可以对GUI继续做其他操作,该请求是异步请求(Ajax引擎发送请求时,没有打断用户的操作)
⑥ 服务器的web组件对请求进行处理
⑦ 服务器可能会调用到数据库或者处理业务逻辑的Java类
⑧ 服务器将处理结果响应给(只返回部分数据,可以是xml或者文本)Ajax引擎
⑨ 监听器通过Ajax引擎获取响应数据(xml或者文本)
⑩ 监听器对GUI中的数据进行更新(局部更新,不是整个页面刷新)
整个过程中大部分是通过JS实现的,响应数据可能是xml,所以Ajax可以看做是多种技术的融合。
2 Ajax编程
第一步 获得XmlHttpRequest对象
该对象由浏览器提供,但是该类型并没有标准化。
ie和其他浏览器不同,其他浏览器都支持该类型,而ie不支持。
function getXmlHttpRequest(){
var xhr = null;
if((typeof XMLHttpRequest) != 'undefined'){
xhr = new XMLHttpRequest();
}else{
xhr = new ActiceXObject(Microsoft.XMLHttp);
}
return xhr;
}
第二步 使用XmlHttpRequest向服务器发请求
a. 发送get请求
function change(v1) {
var xhr = getXmlHttpRequest();
/*open(请求方式,请求地址,同步/异步)
请求方式:get/post
请求地址:如果是get请求,请求参数添加到地址之后
比如 get_comments.do?name=QQ
同步/异步:true表示异步
*/
xhr.open("get", encodeURI("get_comments.do?name=" + v1), true);
/*注册一个监听器(即当xhr的状态发生改变产生了readystatechange事件,
该事件会由一个函数f1来进行处理,这个函数里需要获得服务器返回的数据,
然后更新页面)
*/
xhr.onreadystatechange = f1;
/*只有调用send方法之后,请求才会真正发送*/
xhr.send(null);
}
b. 发送post请求
function change2(v1){
var xhr = getXmlHttpRequest();
xhr.open("post","get_comments.do",true);
//必须添加一个消息头 content-type
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
xhr.onreadystatechange = f1;
xhr.send("name=" + v1);
}
第三步 在服务器端处理请求
第四步 在监听器当中,处理服务器返回的响应
xhr.onreadystatechange = f1;
function f1(){
if(xhr.readyState == 4){
var txt = xhr.responseText;
document.getElementById("d1").innerHTML = txt;
}
}
或者
xhr.onreadystatechange =function(){
//编写相应的处理代码
if(xhr.readyState == 4){
//只有readyState等于4,xhr才完整地接收到了服务器返回的数据
//获得文本数据
var txt = xhr.responseText;
//获得一个xml dom 对象
var xml = xhr.responseXML;
//dom操作 更新页面
document.getElementById("d1").innerHTML = txt;
}
}
关于Ajax的其他应用,可以参考网盘文件。
(1)关于get请求中,ie浏览器的缓存功能,使得并非每一次触发事件都发起请求的问题的解决
(2)关于get请求和post请求中,包含中文时的编码问题解决等。
Ajax的用法的更多相关文章
- Ajax.ActionLink 用法
Ajax.ActionLink 用法 Ajax 属性的ActionLink方法可以创建一个具有异步行为的锚标签. ActionLink方法的第一个参数指定了链接文本,第二个参数是要异步调用的操作的名称 ...
- MVC学习十二:Ajax.ActionLink用法
Ajax.ActionLink用法 <!--使用Ajax.BeginForm必须引用的js文件--> <script type="text/javascript" ...
- 关于Jquery Ajax的用法
今天简单描述一下Jquery Ajax的用法,和我在使用过程中的一些看法,仅供自己娱乐和大家参考值之用! Jquery Ajax的重要性不言而喻,只从Jquery面世之后,终于解救了像我这种既做前台又 ...
- js进阶ajax基本用法(创建对象,连接服务器,发送请求,获取服务器传过来的数据)
js进阶ajax基本用法(创建对象,连接服务器,发送请求,获取服务器传过来的数据) 一.总结 1.ajax的浏览器的window对象的XMLHtmlRequest对象的两个重要方法:open(),se ...
- ajax和springmvc的请求响应原理——深入理解jQuery中$.get、$.post、$.getJSON和$.ajax的用法
1,四大重要部分: 请求链接 post请求和get请求 请求参数形式 响应内容形式 2,从springmvc的controller角度,controller能接收到请求的前提 请求链接必须对应 pos ...
- 深入理解jQuery中$.get、$.post、$.getJSON和$.ajax的用法
当我们用javascript写ajax程序写得很“开心”的时候,突然有人告诉你有一种东西叫jquery,它会告诉你不直接和HttpRequest是多么的快乐,同时你再也不需要再烦恼纠结的ajax乱码问 ...
- 详细解读Jquery的$.get(),$.post(),$.ajax(),$.getJSON()用法
一,$.get(url,[data],[callback]) 说明:url为请求地址,data为请求数据的列表,callback为请求成功后的回调函数,该函数接受两个参数,第一个为服务器返回的数据,第 ...
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法
以下是本人原创,如若转载和使用请注明转载地址.本博客信息切勿用于商业,可以个人使用,若喜欢我的博客,请关注我,谢谢!博客地址 一.jQuery中调用ajax的4种方法:$.get.$.post.$ge ...
- 理解jQuery中$.get、$.post、$.getJSON和$.ajax的用法
ajax的4种方法:$.get.$.post.$getJSON.$ajax. 1.$.get $.get()方法使用GET方式来进行异步请求,它的语法结构为: $.get( url [, data] ...
- ajax实战用法详解
谦虚使人进步,总结使人提高! 以下5个方法执行一般Ajax请求的简短形式,在处理复杂的Ajax请求时应该使用jQuery.ajax() 1.load(url,[data],[callback])载入远 ...
随机推荐
- FZU1759(SummerTrainingDay04-B 欧拉降幂公式)
Problem 1759 Super A^B mod C Accept: 1056 Submit: 3444Time Limit: 1000 mSec Memory Limit : 327 ...
- django-csrf攻击
一.原理 csrf(Cross Site Request Forgery, 跨站域请求伪造:CSRF 攻击允许恶意用户在另一个用户不知情或者未同意的情况下,以他的身份执 行操作. CSRF 攻击是黑客 ...
- 1-1 sacc(scss)入门
定义: CSS 预处理器定义了一种新的语言,其基本思想是,用一种专门的编程语言,为 CSS 增加了一些编程的特性,将 CSS 作为目标生成文件,然后开发者就只要使用这种语言进行编码工作. 通俗的说,“ ...
- 关于对DI和IOC的概念理解
在spring框架学习过程中,涉及到两个新名词:DI和IOC.开始总是混淆两者的概念,稀里糊涂,后来上网搜了一下又和同学讨论之后,基本上理解了二者的概念.实际上DI(依赖注入)和IOC(控制反转)就是 ...
- JS 解决 IOS 中拍照图片预览旋转 90度 BUG
上篇博文[ Js利用Canvas实现图片压缩 ]中做了图片压缩上传,但是在IOS真机测试的时候,发现图片预览的时候自动逆时针旋转了90度.对于这个bug,我完全不知道问题出在哪里,接下来就是面向百度编 ...
- JSP基本语法总结【1】(jsp工作原理,脚本元素,指令元素,动作元素)
时隔半年,回头对jsp复习整理一下,温故而知新. jsp工作原理: jsp服务器管理jsp页面分两个阶段:转换阶段(translation phase)和执行阶段(execution phase). ...
- 基于纤程(Fiber)实现C++异步编程库(一):原理及示例
纤程(Fiber)和协程(coroutine)是差不多的概念,也叫做用户级线程或者轻线程之类的.Windows系统提供了一组API用户创建和使用纤程,本文中的库就是基于这组API实现的,所以无法跨平台 ...
- imei和imsi
imei.imsi是大部分应用自动采集的设备信息,Android中需要在MINIFEST声明权限,6.0以上手机还需要用户显示授权才可以正常获取.这两个标识有什么区别.联系?为什么应用这么执着于采集这 ...
- Oracle EBS OM 发放订单
DECLARE l_header_rec OE_ORDER_PUB.Header_Rec_Type; l_line_tbl OE_ORDER_PUB.Line_Tbl_Type; l_action_r ...
- 如何用SQL脚本在SQL Server Replication中创建合并复制,以及怎么创建分区合并复制
假设我们要创建合并复制的发布端数据库是EFDemo其中有四张表,订阅端数据库是EFDemoSubscription,如下图所示: 首先创建发布端快照代理Sql agent job:"EFDe ...