Ajax = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)
Ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。
GET 还是 POST?
与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。
然而,在以下情况中,请使用 POST 请求:
- 无法使用缓存文件(更新服务器上的文件或数据库)
- 向服务器发送大量数据(POST 没有数据量限制)
- 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠
异步 - true 或 false?
- XMLHttpRequest 对象如果要用于 Ajax 的话,其 open() 方法的 async 参数必须设置为 true
- 不推荐使用 async=false,但是对于一些小型的请求,也是可以的。
- 请记住,JavaScript 会等到服务器响应就绪才继续执行。如果服务器繁忙或缓慢,应用程序会挂起或停止。
- 注意:当您使用 async=false 时,请不要编写 onreadystatechange 函数 —— 把代码放到 send() 语句后面即可
每当 readyState 改变时,就会触发 onreadystatechange 事件。
readyState 属性存有 XMLHttpRequest 的状态信息。
下面是 XMLHttpRequest 对象的三个重要的属性:
属性 | 描述 |
---|---|
onreadystatechange | 存储函数(或函数名),每当 readystate 属性改变时,就会调用该函数。 |
readystate | 存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。
|
status | 200: “ok” 404: 未找到页面 |
1 直接使用JavaScript的Ajax简单示例
1 | function showCustomer(str) |
showCustomer() 函数执行以下任务:
- 检查是否已选择某个客户
- 创建 XMLHttpRequest 对象
- 当服务器响应就绪时执行所创建的函数
- 把请求发送到服务器上的文件
- 请注意我们向 url 添加了一个参数 q (带有输入域中的内容)
2 使用JavaScript对Ajax封装
此处参考了Snandy 的比较成熟完整的封装,包含了超时检查、异常处理、新API解析JSON的特性,推荐
1 | /******************************************************************************************************* |
3 ASP.NET中的Ajax控件
微软很贴心地为开发者封装了一套傻瓜化的Ajax控件,拖拖控件就可以实现Ajax
1 | <form id="form1" runat="server"> |
用法:
①一个页面只能有一个ScriptManager(脚本控制器)控件,并且放在其他Ajax控件的前面,它是ASP.NET Ajax的基础,用来处理页面上的所有Ajax组件以及页面局部更新,生成相应的客户端代理脚本
②在ScriptManager还可以设置超时处理、异常处理等属性,详见MSDN
③具体实现Ajax的部分放在UpdatePanel控件,可以在该控件里指定事件需要局部刷新还是整页刷新,默认是异步的局部刷新。如果要想实现整页刷新提交,像平时不用Ajax控件的效果,只需在<Triggers>
标签里面指定<asp:PostBackTrigger ControlID="btnNonAjax" />
,ControlID就是不需要异步提交的控件,如此指定后该控件的任何事件都是整页刷新提交
接下来是对应的页面后台代码:
1 | public partial class _Default : System.Web.UI.Page |
①由于这种类似于拖控件的方式生成的html代码量巨大,不灵活也不好控制细节,故现在基本上较少采用了
②如果需要实现回调功能,可以使用ClientScriptManager.GetCallbackEventReference
方法配合JavaScript实现,详见MSDN
4 JQuery 实现Ajax
4.1 JQuery.get()
语法:$(selector).get(url,data,success(response,status,xhr),dataType)
参数url是必须的,其他可选
示例:
1 | $.get("test.php", function(data){ |
4.2 JQuery.post()
语法:jQuery.post(url,data,success(data, textStatus, jqXHR),dataType)
参数url是必须的,其他可选
示例:
1 | $.post("test.php", { name: "John", time: "2pm" }, |
4.3 jQuery.ajax()
语法:jQuery.ajax([settings])
上面两个get()和post()方法都是ajax()方法的简化写法;参数settings是集合,可选
常用参数列表:(详见W3School)
参数名 | 类型 | 描述 |
---|---|---|
url | String | (默认值: 当前页地址)发送请求的地址。 |
type | String | (默认值: “GET”)请求方式 (“POST” 或 “GET”), 默认为 “GET”。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。 |
timeout | Number | 设置请求超时时间(毫秒)。此设置将覆盖全局设置。 |
async | Boolean | (默认值: true)默认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。 |
beforeSend | Function | 发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 http 头。XMLHttpRequest 对象是唯一的参数。如果返回 false 可以取消本次 Ajax 请求。 |
complete | Function | 请求完成后回调函数 (请求成功或失败之后均调用)。参数: XMLHttpRequest 对象和一个描述请求类型的字符串。 |
data | String | 发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:[“bar1”, “bar2”]} 转换为 ‘&foo=bar1&foo=bar2’。 |
dataType | String | 预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:
|
success | Function | 请求成功后的回调函数。参数:由服务器返回,并根据 dataType 参数进行处理后的数据;描述状态的字符串。 |
error | Function | (默认值: 自动判断 (XML 或 HTML))请求失败时调用此函数。有以下三个参数:XMLHttpRequest 对象、错误信息、(可选)捕获的异常对象。如果发生了错误,错误信息(第二个参数)除了得到 null 之外,还可能是 “timeout”, “error”, “notmodified” 和 “parsererror”。 |
cache | Boolean | (默认值: true,datatype 为 script 和 jsonp 时默认为 false)设置为 false 将不缓存此页面。 jQuery 1.2 新功能。 |
contentType | String | (默认值: “application/x-www-form-urlencoded”)发送信息至服务器时内容编码类型。默认值适合大多数情况。如果你明确地传递了一个 content-type 给 $.ajax() 那么它必定会发送给服务器(即使没有数据要发送)。 |
global | Boolean | 是否触发全局 Ajax 事件。默认值: true。设置为 false 将不会触发全局 Ajax 事件,如 ajaxStart 或 ajaxStop 可用于控制不同的 Ajax 事件。 |
ifModified | Boolean | (默认值: false)仅在服务器数据改变时获取新数据。使用 http 包 Last-Modified 头信息判断。在 jQuery 1.4 中,它也会检查服务器指定的 ‘etag’ 来确定数据没有被修改过。 |
processData | Boolean | (默认值: true)默认情况下,通过data选项传递进来的数据,如果是一个对象(技术上讲只要不是字符串),都会处理转化成一个查询字符串,以配合默认内容类型 “application/x-www-form-urlencoded”。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。 |
5 总结
方便实用选jQuery,性能优先选JavaScript封装。UpdatePanel?算了吧。。。
本文待补充
参考资料:
Ajax 基本封装
jQuery Ajax 实例 全解析
基于.NET三种Ajax技术的运用——原生JS、ASP.NET Ajax和.NET回调技术