Ajax概要:

Ajax不是个全新的技术,它是多种技术合并在一起产生的,包括XHTML,CSS,JavaScript,XmlHttpRequest,XML,JSON,DOM等

优点:(这也解释了为何我们需要Ajax技术)

传统页面被点击将与服务器通信后将刷新整个页面。用Ajax只需刷新局部,而且如果数据在本地,根本不必和服务器通信。

缺点:
Ajax整合了大量技术,因此可能会有浏览器兼容性问题,如果该浏览器不支持某项技术,就可能导致运行失败,因此一定要多浏览器测试。

步骤:

用传统JavaScript方式开发个使用Ajax技术的web页面的话可细分为以下5个步骤:

Step1:编写HTML和CSS来布局页面

Step2:编写一个函数初始化页面

Step3:编写一个函数创建请求对象

Step4:从服务器得到数据

Step5:在页面上更新显示

现在很多库(如jQuery,Backbone)都提供了便利的ajax函数供使用,但究其本质就是将上述步骤3进行封装,以简化代码开发

Step1详解:(编写HTML和CSS来布局页面)

(该步骤需要有HTML和CSS知识储备,非本文详解内容)

用HTML和CSS先编写个静态页面,页面内有个用户名控件:

我们希望在输入完用户名后,Textbox失去焦点后,就自动将用户名发送到服务器端去验证。

如果是验证结果失败(如该用户名已被注册)则Textbox右侧显示个叉图标。如果验证结果成功,Textbox右侧显示个勾图标。

Step2详解:(编写一个函数初始化页面)

HTML里加载js文件(如my_validation.js)

js文件里需要使BOM的window对象在加载页面时对页面先初始化(类似jQuery的$(document).ready(function(){...})

  1. window.onload = initPage;<pre name="code" class="javascript">
  2. function initPage() {
  3. document.getElementById("username").onblur = checkUsername;    //用户名失去焦点时触发回调函数
  4. }
  5. function checkUsername() {    //检查用户名的回调函数暂时TBD
  6. alert("Username lose focus");
  7. }

输入好用户名后,离开Textbox将弹出警告框

Step3详解:(编写一个函数创建请求对象)

  1. function createRequest() {
  2. try {
  3. request = new XMLHttpRequest();
  4. } catch (tryMS) {
  5. try {
  6. request = new ActiveXObject("Msxml2.XMLHTTP");
  7. } catch (otherMS) {
  8. try {
  9. request = new ActiveXObject("Microsoft.XMLHTTP");
  10. } catch (failed) {
  11. request = null;
  12. }
  13. }
  14. }
  15. return request;
  16. }

从函数中也可以看出,IE和其他浏览器对请求对象的实现有所不同。甚至低版本IE和IE7以上版本的请求对象的实现亦不同。因此要对IE和非IE区别实现才能全浏览器适用。

更多请参照w3schools:http://www.w3schools.com/ajax/ajax_xmlhttprequest_create.asp

有了请求对象之后就可以完成步骤2里的检查用户名的回调函数了:

  1. function checkUsername() {
  2. request = createRequest();    //new一个请求对象
  3. if (request == null)
  4. alert("Unable to create request");
  5. else {
  6. var username = escape(document.getElementById("username").value);    //获取页面上用户输入的用户名
  7. var url= "checkName.php?username=" + username;    //将用户名作为URL的一部分(因用Get而非Post方式)传给服务器端验证脚本
  8. request.onreadystatechange = showUsernameStatus;  //注册回调函数,服务器端验证完毕后会调用该函数
  9. request.open("GET", url, true);    //用Get而非Post方式发送请求给服务器,true表示异步
  10. request.send(null);                //不需要额外的参数,如用Post方式需要传递参数
  11. }
  12. }
  13. function showUsernameStatus() {    //服务器端验证完毕后调用该回调函数,暂时TBD
  14. alert("Call Web Server success");
  15. }

服务器端新建验证用户名的PHP脚本checkName.php,如该用户名已注册可返回denied,未注册可返回okay。PHP非本文内容不详解。

Step4详解:(从服务器得到数据)

如果你顺利做到Step3,会发现用户名Textbox失去焦点后,弹了5次”Call Web Server success“警告框。因为服务器收到请求对象后会将请求对象的readyState属性从0~4依次返回,共返回5次。请求对象的各属性详解:

请求对象的各属性请参照:http://www.w3schools.com/dom/dom_http.asp (XMLHttpRequest Object Properties)

readyState属性:0表示连接尚未初始化,1表示连接初始化了,2表示请求正在处理,3表示得到服务器响应,4表示服务器处理完请求。

state属性:服务器返回的一个HTTP状态码,如request.status == 200表示成功,404表示没找到

responseXML属性:服务器返回的XML格式的信息,如果返回的非XML格式的信息该值为空

statusText属性:如有问题,可从这个属性得到问题的描述

responseText属性:服务器返回的文本信息,如果返回的非文本格式信息该值为空

onreadystatechange属性:回调函数

  1. function showUsernameStatus() {    //Step3里创建的回调函数
  2. if (request.readyState == 4 && request.status == 200) {    //请求处理成功处理完毕
  3. if (request.responseText == "okay") {    //Step3里的PHP里验证成功将返回字符串okay
  4. alert("username OK");
  5. } else {
  6. alert("username has been registed");
  7. }
  8. }
  9. }

Step5详解:(在页面上更新显示)

将Step4里的回调函数根据业务需要补充完整:

  1. function showUsernameStatus() {
  2. if (request.readyState == 4 && request.status == 200) {
  3. if (request.responseText == "okay") {
  4. document.getElementById("username").className = "approved";
  5. document.getElementById("register").disabled = false;
  6. } else {
  7. document.getElementById("username").className = "denied";
  8. document.getElementById("username").focus();
  9. document.getElementById("username").select();
  10. document.getElementById("register").disabled = true;
  11. }
  12. }
  13. }

如果服务器端PHP返回okay,则将用户名Textbox的CSS式样更新为approved。CSS式样中会在Textbox右侧显示勾图片:

如果服务器端PHP返回denied,则将用户名Textbox的CSS式样更新为denied。CSS式样中会在Textbox右侧显示叉图片:

总结:

传统页面只能和服务器同步交互。即发出请求后,在得到服务器响应前页面将呈现“僵死”状态,用户体验很糟糕。得到服务器响应后,需要刷新全页面,速度也比较慢。

而Ajax技术使得页面能够和服务器异步交互。即发出请求后,在得到服务器响应前页面仍能被用户正常使用。得到服务器响应后,也只需要刷新局部页面即可。数据碎片化,速度快。

另外jQuery库中除了提供ajax方法外,还提供get,getJSON,getScript,post,load几个快捷方式,它们最终都将调用ajax方法。

 
 

Ajax概要:的更多相关文章

  1. XMLHttpRequest 与 Ajax 概要

    关于XMLHttpRequest 开发者使用XMLHttpRequest对象与服务端进行交互(发送http请求.接受返回数据等),可以在不打断用户下一步操作的情况下刷新局部页面.XMLHttpRequ ...

  2. ajax请求处理概要

    /** *不关心参数传递与参数返回的形式. */ url = ctxPath + '/ccb/xxx '; $.get(url); $.post(url); /** * 常见形式. */ var ur ...

  3. 前端MVC学习总结(一)——MVC概要与angular概要、模板与数据绑定

    一.前端MVC概要 1.1.库与框架的区别 框架是一个软件的半成品,在全局范围内给了大的约束.库是工具,在单点上给我们提供功能.框架是依赖库的.AngularJS是框架而jQuery则是库. 1.2. ...

  4. Ajax基础

    1 概要 异步JavaScript和XML(Asynchronous Javascript And XML,Ajax)就是使用js来收发来自web服务器的数据,且无需重载整个页面的技术. 注 :xml ...

  5. C#高级知识点概要(2) - 线程和并发

    原文地址:http://www.cnblogs.com/Leo_wl/p/4192935.html 我也想过跳过C#高级知识点概要直接讲MVC,但经过前思后想,还是觉得有必要讲的.我希望通过自己的经验 ...

  6. 前端MVC学习笔记(一)——MVC概要与angular概要、模板与数据绑定

    一.前端MVC概要 1.1.库与框架的区别 框架是一个软件的半成品,在全局范围内给了大的约束.库是工具,在单点上给我们提供功能.框架是依赖库的.AngularJS是框架而jQuery则是库. 1.2. ...

  7. 深入理解ajax系列第四篇——请求实例

    前面的话 在使用ajax的过程中,常用的请求方式是GET和POST两种.本文将以实例的形式来详细说明这两种请求方式 GET GET是最常见的请求类型,最常用于向服务器查询某些信息.必要时,可以将查询字 ...

  8. AJAX学习前奏----JS基础加强

     AJAX学习前奏----JS基础加强 知识概要: 1.js类&属性&方法的定义 2.静态属性与方法 3.构造方法 4.原型的使用 5.Object对象直接加属性和方法 6.JSO ...

  9. 前端MVC Vue2学习总结(一)——MVC与vue2概要、模板、数据绑定与综合示例

    一.前端MVC概要 1.1.库与框架的区别 框架是一个软件的半成品,在全局范围内给了大的约束.库是工具,在单点上给我们提供功能.框架是依赖库的.Vue是框架而jQuery则是库. 1.2.AMD与CM ...

随机推荐

  1. Swift 之模糊效果(毛玻璃效果,虚化效果)的实现

    前言: 之前项目中有用到过Objective-C的的模糊效果,感觉很是不错,而且iOS8之后官方SDK也直接提供了可以实现毛玻璃效果的三个类:UIBlurEffect.UIVibrancyEffect ...

  2. REGEXP 正则的实现两个字符串组的匹配。(regexp)

    主要懂3个mysql的方法:replace[替换]   regexp[正则匹配]    concat[连接]   由于某些原因,有时候我们没有按照范式的设计准则而把一些属性放到同一个字符串字段中.比如 ...

  3. 诡异的localhost无法连接

    上午试了localhost发现提示无法连接,ping了下localhost,能够ping通. 重启了Apache,还是无法解决. 试着停止了Apache服务,然后再连接localhost,发现浏览器提 ...

  4. Curator leader 选举(一)

    要想使用Leader选举功能,需要添加recipes包,可以在maven中添加如下依赖: <dependency> <groupId>org.apache.curator< ...

  5. 第一个Mac shell 小脚本

    大多数程序员都喜欢偷懒的,我也不例外.相信好多Android开发的coder 在网络http请求方面,会浪费很多时间在接口调试这里..有时候,自己写了一个小测试,行还好,不行的话,还要跟写后台的哥们一 ...

  6. 关于H5框架之Bootstrap的小知识

    浏览器支持 旧的浏览器可能无法很好的支持 Bootstrap 支持 Internet Explorer 8 及更高版本的 IE 浏览器 CSS源码研究 我们不是在head里面引入了下面这些文件么 &l ...

  7. sublime text 插件(前端自用)

    一.软件安装 ST中文论坛:http://sublimetext.iaixue.com/  或者 http://sublimetext.iaixue.com/dl/#sublime_text_3103 ...

  8. placehoder不兼容ie9以下和opero12以下

    颜色设置 解决方案一: ::-webkit-input-placeholder { /* WebKit browsers */ color:#999; } :-moz-placeholder { /* ...

  9. Java面向对象课程小结

    1.什么是对象?什么是类? 类和对象的关系 定义类的方法 方法五要素 new关键字 引用类型变量的赋值 null和nullException null大小写的区别 2.方法 重载和重写 构造 方法,带 ...

  10. adb devices出现no permissions

    在做Android开发的时候,有些设备插入USB调试线,无法调试,出现以下错误: joey 09:58 $ adb devices List of devices attached 20080411 ...