日期:2014-05-16 浏览次数:20678 次
日期:2012/03/07
?
最 近几年很多网站,事实上基本所有的网站都使用一个技术 - AJAX来提供流畅并且高效的用户体验。无论是出名的Google Maps还是Gmail,或者是流行的javascript框架-jQuery Mobile,都使用AJAX来获取后台数据,并且实时更新用户浏览页面。
使用javascript代码来构建一个AJAX应用可能需要技巧。但是,很多的javascript类库,包括jQuery都已经内建支持AJAX,这样使得开发一个AJAX驱动的网站或者应用变得非常简单。
在这个教程中,我们将学习使用jQuery来执行基本的AJAX请求操作。 你将会学习:
注意:本文主要介绍javascript端的使用,如何你需要了解后台,请参考你所使用的语言。
简单说,AJAX是一个帮助你的浏览器和服务器异步通讯的javascript技巧。是A synchronous J avaScript A nd X ML的缩写,和传统的web编程比较来说,他们有如下区别:
因为AJAX的请求往往在后台发生,用户在阅读网页的时候,javascript代码可以继续在后台工作。这个过程对于用户来说是不可见的。并且不会打扰用户目前浏览的页面内容。这一点使得web应用更接近于桌面应用的行为。
AJAX的基础是javascript中的XMLHttpRequest对象,这个对象提供了各种方法,例如,open(),send()和onreadystatechange()方法来创建AJAX的请求和响应。
书写跨浏览器的AJAX的js代码可能非常费时。很幸运的是,jQuery提供了使用简单的AJAX方法帮助你跳过底层的处理 。
我们首先来看看最重要的方法:$.get().
jQuery的$.get()方法提供了你简单的方式来处理HTTP GET方法,通常用来获取web页面或者图片。对应的是POST方法。使用$.get()方法非常简单,如下:
$.get( url );
url是服务器端的一个地址,可以是服务器端脚本或者是一个静态页面,如下:
$.get( "http://gbin1.com/index.html" );
或者一个动态的document
$.get( "http://gbin1.com/index.jsp" );
当然,同时也支持参数,如下:
$.get( "http://gbin1.com/index.jsp?category=jquery" );
一个简单的方法来处理是使用参数对象来发送http参数,如下:
var gbdata={category:"jquery", subcategory:"ajax"}; $.get( "http://gbin1.com/index.jsp", data );?
当然以下形式也没有问题:
var gbdata="category=jquery&subcategory=ajax"; $.get( "http://gbin1.com/index.jsp", data );?
这里我们使用的$.get()方法都是发送请求到服务器,但是有的时候,我们需要得到服务器返回的内容,例如,一些数据。这里我们如何处理呢?答案就是书写一个回调(Callback)方法,一个AJAX请求的返回数据会作为这个回调方法的参数,如下:
function myCallback( returnedData ) { ? // 这里我们可以处理returnedData,例如,封装数据生成HTML展现给用户 }
一旦你创建了你的回调函数,你就可以将它传递给$.get()方法,如下:
var gbdata={category:"jquery", subcategory:"ajax"}; $.get( "http://gbin1.com/index.jsp", gbdata, myCallback );
服务器端的数据返回类型可以是不同的格式,包括,XML,JSON和javascript,或者HTML。缺省情况下,jQuery会尽力自己判断返回的数据格式,并且正确解析,当然最好的大家自己指定数据格式。
参数可以为以下:
例如,如果你知道你的服务器端返回JSON格式,你可以调用$.get(),如下:
$.get( "http://gbin1.com/index.jsp", gbdata, myCallback, "json" );
这里是一个完整的例子,展示了如何使用$.get()方法来调用一个AJAX请求并且返回响应内容。首先创建一个文本文件如下:
{ ? "site": "GBin1.com", ? "date": "2011/06/06", ? "tag": "jQuery", ? "pages": 800 }
以上文件模拟了一个JSON响应的结果。下面我们保存另外一个html文件,如下:
<!doctype html> <html lang="en"> <head> <title>Site Info Demo for jQuery $.get()</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <style> #container{ padding: 100px; font-size: 12px; font-family: arial; } #result{ padding: 10px 0; } #result li{ padding: 10px 0; } </style> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script> <script> $( function() { $('#showinfo').click( function() { var data = { site: "GBin1.com", date: "20120318" }; $.get( "siteinfo.txt", data, success, "json" ); } ); function success( siteData ) { var result = "<li>Site Name:" + siteData.site + "</li>"; resu