以下文字根据李炎恢——jQuery教程整理而成。

Ajax全称为:“Asynchronous JavaScript and XML”(异步JavaScript和XML),它并不是JavaScript的一种单一技术,而是利用了一系列交互式网页应用相关的技术所形成的结合体。使用Ajax,我们可以无刷新状态更新页面,并且实现异步提交,提升了用户体验。

Ajax概述

Ajax这个概念是由Jesse James Garrett在2005年发明的。它本身不是单一技术,是一串技术的集合,主要有:

  1. JavaScript,通过用户或其他与浏览器相关事件捕获交互行为
  2. XMLHttpRequest对象,通过这个对象可以在不中断其它浏览器任务的情况下向服务器发送请求
  3. 服务器上的文件,以XML、HTML或JSON格式保存文本数据
  4. 其它JavaScript,解释来自服务器的数据(比如PHP从MySQL获取的数据)并将其呈现到页面上

由于Ajax包含众多特性,优势与不足也非常明显。优势主要以下几点:

  1. 不需要插件支持(一般浏览器且默认开启JavaScript即可)
  2. 用户体验极佳(不刷新页面即可获取可更新的数据)
  3. 提升Web程序的性能(在传递数据方面做到按需发送,不必整体提交)
  4. 减轻服务器和带宽的负担(将服务器的一些操作转移到客户端)

而Ajax的不足有以下几点:

  1. 不同版本的浏览器对XMLHttpRequest对象支持度不足(比如IE5之前)
  2. 前进、后退的功能被破坏(因为Ajax永远在当前页,不会记住前后页面)
  3. 搜索引擎的支持度不够(因为搜索引擎爬虫还不能理解JS引起变化数据的内容)
  4. 开发调试工具缺乏(相对于其他语言的工具集来说,JS或Ajax调试开发少的可怜)

异步和同步

使用Ajax最关键的地方,就是实现异步请求、接受响应及执行回调。那么异步与同步有什么区别呢?我们普通的Web程序开发基本都是同步的,意为执行一段程序才能执行下一段,类似电话中的通话,一个电话接完才能接听下个电话;而异步可以同时执行多条任务,感觉有多条线路,类似于短信,不会因为看一条短信而停止接受另一条短信。Ajax也可以使用同步模式执行,但同步的模式属于阻塞模式,这样会导致多条线路执行时又必须一条一条执行,会让Web页面出现假死状态,所以,一般Ajax大部分采用异步模式。

load方法

jQuery对Ajax做了大量的封装,我们使用起来也较为方便,不需要去考虑浏览器兼容性。对于封装的方式,jQuery采用了三层封装:最底层的封装方法为:$.ajax(),而通过这层封装了第二层,有三种方法:.load()、$.get()和$.post(),最高层是$.getScript()和$.getJSON()方法。

.load()方法可以传递三个参数:url(必须,请求html文件的url地址,参数类型为String)、data(可选,发送的key/value数据,参数类型为Object)、callback(可选,成功或失败的回调函数,参数类型为函数Function)。

如果想让Ajax异步载入一段HTML内容,我们只需要一个HTML请求的url即可。

Ajax.html代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Ajax</title>
<script type="text/javascript" src="jquery-1.12.3.js"></script>
<script type="text/javascript" src="demo.js"></script>
<link rel="stylesheet" type="text/css" href="style.css" />
</head>
<body>
<input type="button" value="异步加载数据" />
<div id="box"> </div>
</body>
</html>

要异步加载的数据,test.html:

<span class="title">瓢城web俱乐部</span>
<span class="url">www.ycku.com</span>

jQuery代码:

$("input").click(function() {
$("#box").load("test.html");
});

如果想对载入的HTML进行筛选,那么只要在url参数后面跟着一个选择器即可。

$("input").click(function() {
$("#box").load("test.html .url"); //带选择器的url
});

如果是服务器文件,比如.php(妈的,没学过啊)。一般不仅需要载入数据,还需要向服务器提交数据,那么我们就可以使用第二个可选参数data。向服务器提交数据有两种方式:get和post。

$("input").click(function() {
$("#box").load("test.php?url=ycku"); //不传递data,则默认get方式
});

get方式接受的PHP(没学过php,这是一个问题)

<?php
if($_GET['url'] == 'ycku') {
echo "瓢城Web俱乐部";
} else {
echo "木有!";
}
?>
$("input").click(function() {
$("#box").load("test.php", { //传递data,则为post方式
url:"ycku"
});
});

post方式接受的PHP:

<?php
if($_POST['url'] == 'ycku') {
echo "瓢城Web俱乐部";
} else {
echo "木有!";
}
?>

在Ajax数据载入完毕之后,就能执行回调函数callback,也就是第三个参数。回调函数也可以传递三个可选参数:responseText(请求返回)、textStatus(请求状态)、 XMLHttpRequest(XMLHttpRequest 对象)。

jQuery代码如下:

$("input").click(function() {
$("#box").load("test.php", {
url:"ycku"
}, function(response, status, xhr) {
// alert(response); //返回响应
// $("#box").html(response+"123"); // alert(status);
// if(status == "success") {
// alert("成功后的处理");
// } // alert(xhr.responseText); // xhr.responseText等价于response
// alert(xhr.responseXML); //undefined
// alert(xhr.status); //200
alert(xhr.statusText); //OK
});
});

注意:status得到的值, 如果成功返回数据则为:success,否则为:error。XMLHttpRequest对象属于JavaScript范畴,可以调用一些属性如下:

属性名 说明
responseText 作为响应主体被返回的文本
responseXML 如果响应主体内容类型是“text/xml”或“applicaton/xml”,则返回包含响应数据的XML DOM文档
status 响应的HTTP状态
statusText HTTP状态的说明

如果成功返回数据,那么xhr对象的statusText属性则返回'OK'字符串。除了'OK'的状态字符串,statusText属性还提供了一系列其他的值,如下:

HTTP状态码 状态字符串 说明
200 OK 服务器成功返回了页面
400 Bad Request 语法错误导致服务器不识别
401 Unauthorized 请求需要用户认证
404 Not found 指定的URL在服务器上找不到
500 Internal Server Error 服务器遇到意外错误,无法完成请求
503 ServiceUnavailable 由于服务器过载或维护导致无法完成请求

初学Ajax(一)的更多相关文章

  1. 初学Ajax(三)

    $.ajax() $.ajax()是所有ajax方法中最底层的方法,所有其他方法都是基于$.ajax()方法的封装.这个方法只有一个参数,传递一个各个功能键值对的对象. $.ajax()方法对象参数表 ...

  2. 初学Ajax(二)

    $.get()和$.post() .load()方法是局部方法,因为它需要一个包含元素的jQuery对象作为前缀.而$.get()和$.post()是全局方法,无须指定某个元素.对于用途而言,.loa ...

  3. 初学Ajax

    AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异步 JavaScript和 ...

  4. 初学 Ajax(涉及 php)

    一直知道 ajax 但是尚未真正了解, 这次看了慕课网的<Ajax全接触>,算是有所收获,入了个门. 需要用到php,因为 Ajax也是向服务器请求(不知道这么解释对不对), 所以还需要配 ...

  5. 关于AJAX使用中出现中文乱码的问题

    自己初学AJAX,遇到一个棘手的bug就是xmlHttp.open("get",url,false);url里面有中文,结果出现乱码.不过最后在百度,和诸位博主的帮助下,成功解决了 ...

  6. jQuery Ajax请求 .net 一般处理程序

    初学ajax 一个简单的功能,调试了2个小时,代码如下虽然成功了 但是有错误 <!DOCTYPE html> <html> <head> <meta http ...

  7. 使用Ajax时[object%20object] 报错的解决方案

    踩坑经过 最近初学Ajax,当我想把Ajax应用到自己项目中的时候,没有达到理想的效果,还报了如下错误: 点击图中报错,产生报错页面如下: 当时写的Ajax如下: // 提交修改密码表单 $(&quo ...

  8. 2014年5月份第4周51Aspx源码发布详情

    最基本wcf服务器与客户端交互源码  2014-5-26 [VS2003]源码描述:本示例讲解的是最基本的wcf语法,示例浏览请先运行服务端,然后在运行客户端,适合想要学习wcf的初学者.仅供借鉴,欢 ...

  9. JS实现仿腾讯微博无刷新删除微博效果代码

    这里演示JS仿腾讯微博无刷新删除效果,将显示在微博列表里的内容删除,运用AJAX技术,无刷新删除微博的内容,参考性强,希望对初学AJAX的朋友有所帮助. 在线演示地址如下: http://demo.j ...

随机推荐

  1. 九度oj 1554 区间问题

    原题链接:http://ac.jobdu.com/problem.php?pid=1554 由数列的前缀和:$\begin{align*}\Large{} S_n &=\Large{}\sum ...

  2. 网络爬虫by pluskid

    网络爬虫(Web Crawler, Spider)就是一个在网络上乱爬的机器人.当然它通常并不是一个实体的机器人,因为网络本身也是虚拟的东西,所以这个“机器人”其实也就是一段程序,并且它也不是乱爬,而 ...

  3. 6 让我们的C#程序开始做点数学运算

    请相信我你只需要懂得最基本的数学运算,就可以从事大多数的软件项目的开发工作.千万不要一提编程,就让数学把你吓跑了.大多数的程序开发人员从事的编程工作是应用系统的开发.这些系统的绝大多数功能,只需要最基 ...

  4. Asp.net mvc与PHP的Session共享的实现

    最近在做的一个ASP.NET MVC的项目,要用到第三方的php系统,为了实现两个系统的互联互通.决定将两者的session打通共享.让asp.net mvc 和php 都能正常访问和修改Sessio ...

  5. 如何在github上fork一个项目来贡献代码以及同步原作者的修改

    [-] 如何贡献自己的力量 如何让自己的项目与原作者的项目保持同步 作为一个IT人,通过github进行学习是最快的成长手 段.我们可以浏览别人的优秀代码.但只看不动手还是成长得很慢,因此为别人贡献代 ...

  6. iTween

    http://u3d.as/content/pixelplacement/i-tween/1s9 download http://itween.pixelplacement.com/documenta ...

  7. 【转】PLSQL developer 连接不上64位Oracle 的解决方法

    PLSQL developer 连接不上64位Oracle 的解决方法 快乐无极 , 2012/06/13 10:10 , 开发文档 , 评论(6) , 阅读(140430) , Via 本站原创 大 ...

  8. appium 调试问题--UiAutomator died while responding to command

    运行程序问题: 解决办法: 手机系统版本较低导致,我是V4.2.2,在android 4.3 系统上运行正常 代码如下: #coding=utf-8 ''' 作者:xxx 功能:测试计算器基本功能 注 ...

  9. NSIS中判断.net framework 是否安装

    在网上找了几个脚本,原理都是读取注册表进行判断,都可以用. 1.CheckDotNetFramework /* * Name: CheckDotNetFramework.nsh * Version: ...

  10. 判断js和css是否加载完成

    在通过ajax或者src动态获取js.css文件的时候,我们常常需要判断文件是否加载完成,以便进行进一步的操作,但是在检测js.css文件是否已经加载的策略上各浏览器并不统一,有很多坑,现在在这里总结 ...