jQuery Ajax开发
2007年10月20日 11:33:03 views TAG: jquery AJAX
jQuery是一个可以简化 JavaScript™以及AJAX(Asynchronous JavaScript +XML,异步Javascript和XML)编程的Javascript库。不同于其他的Javascript库,jQuery有他自己的哲学,使你可以很简单的编写代码。这篇文章就会带领你见识一下jQuery的哲学,探讨一下他的特性以及功能,并且会做一些ajax的示例,以及如何使用plug-in(插件)来扩展jQuery。1. 什么是jQuery?
jQuery是个很优秀的Javascript库,它诞生于2006年,出自JohnResig之手。不管你是一个javascript新手,但是却想尝试一下DOM(Document ObjectModel)以及Ajax的繁杂,抑或你是个javascript专家级人物,但是已经厌倦了反复的重复那无味的DOM以及Ajax脚本,jQuery都将是你的不二选择。
jQuery会帮助你保持代码的简单和简洁。你不必再去写一大堆重复的循环或者是DOM调用脚本,使用jQuery,你将很快找到关键点,并且可以以最少的代码表达你的思想。
jQuery的哲学其实很单一:简单、可重用。当你理解并且认同这种思想的时候,你就可以开始体会一下使用jQuery能让你的编程变得多么轻松愉快了!
2. 一些简单概念
这里是个简单的例子,向你展示jQuery如何影响你编写的代码。做的事情其实很简单,比如对页面上某一区域内的所有链接都添加一个click响应事件,你可以使用一般的Javascript以及DOM来写,代码见Listing1:
Listing 1. DOM scripting without jQuery:
var external_links = document.getElementById('external_links');
var links = external_links.getElementsByTagName('a');
for (var i=0;i < links.length;i++) {
var link = links.item(i);
link.onclick = function() {
return confirm('You are going to visit: ' + this.href);
};
}
Listing 2. DOM scripting with jQuery:
$('#external_links a').click(function() {
return confirm('You are going to visit: ' + this.href);
});
很惊讶,是吧?使用jQuery的话,你可以很快找到关键点,并且只需要表达你需要表达的,
而不需要罗里罗嗦。不需要对这些元素进行循环,click()函数可以处理好这一切。而且你不要谢太多的操作DOM的代码,
你需要的仅仅是使用很少的字符定义你要找的那个元素。
来看一下这段代码是如何工作的,有点小技巧。首先,看到$()函数--jQuery里最有用的最强大的函数.大部分情况下,
你使用这个函数从文档中选择元素.在这个例子中,使用这个函数传递带有一些级联样式表(Cascading Style Sheets,CSS)
语法的字符串,jQuery可以很方便的找到这个元素.
如果你懂一点基本的CSS选择符的只是,我想这个语法应该看起来相当熟悉.在Listing2中,#external_links用来寻找带有id为
external_links的元素.接下来的空格表示jQuery要找到在#external_links元素内的所有的元素.用口语开表达的话有点费劲--
用DOM脚本来写也挺麻烦,不过,在CSS里,没有比这个更简单的了.$()函数返回一个包含与css选择符匹配的所有元素的一个jQuery对象. jQuery对象的概念就像是数组,但是它可能含有许多jQuery函数. 举例来说,你可以调用click函数来绑定一个click事件响应到jQuery对象中的每个元素上.
你还可以向$()函数传递一个元素或者是元素的数组,它将把所有的元素打包成一个jQuery对象.你可能想要把这一特性应用到象窗口对象上面.举例来说, 你有可能使用此函数来加载事件,像这样:
window.onload = function() {
// do this stuff when the page is done loading
};如果使用jQuery的话,你可以这样写:
$(window).load(function() {
// run this when the whole page has been downloaded
});
但是大部分时候,你可能只需要看到一下超文本的标记(HTML).jQuery通过在文档上创建一个很特殊的事件ready来解决这个问题,
使用方法如下:
$(document).ready(function() {
// do this stuff when the HTML is all ready
});
在真正的jQuery风格代码中,这个函数还有一个缩写形式.简单的传递一个函数给$()函数:
$(function() {
// run this when the HTML is done downloading
});到现在位置,我已经向你展示了三种不同的使用$()函数的方法.第四种方式, 你可以使用一个字符串创建一个元素. 结果是一个包含此元素的jQuery对象. Listing3展示了一个增加一段到页面上的例子:
$('<p></p>')
.html('Hey World!')
.css('background', 'yellow')
.appendTo("body");
$('#message').css('background', 'yellow').html('Hello!').show();
使用jQuery,Ajax恐怕不能变得再简单了. jQuery有一系列的函数,可以使简单的事情变得真正简单,让复杂的事情也能变得尽可能
的简单.
Ajax的一个一般用法就是加载一段html代码到页面上的某一区域. 要实现这个,你只要简单的选中这个元素,然后使用load()函数.
下面是个例子,用来更新一些统计信息.
$('#stats').load('stats.html');
Listing 4. Sending data to a page with Ajax:
$.post('save.cgi', {
text: 'my string',
number: 23
}, function() {
alert('Your data has been saved.');
});
Listing 5. Complex Ajax made simple with $.ajax():
$.ajax({
url: 'document.xml',
type: 'GET',
dataType: 'xml',
timeout: 1000,
error: function(){
alert('Error loading XML document');
},
success: function(xml){
// do something with xml
}
});
Listing 6. Working with XML using jQuery:
success: function(xml){
$(xml).find('item').each(function(){
var item_text = $(this).text();
$('<li></li>')
.html(item_text)
.appendTo('ol');
});
}
你可以使用jQuery做一些基本的动画和效果。动画效果的核心就是函数animate(), 它可以随时改变指定的css样式. 举例来说, 你可以改变高度, 宽度, 透明度或者位置.你还可以指定动画的速度, 改变速度的时候你可以使用毫秒(milliseconds),或者你也可以使用预定的速度值: 慢速,正常或者快速(slow, normal, or fast).
下面是个同时改变元素宽和高的动画示例. 注意, 没有初始值,只有最终的值. 初始值可以直接从现有元素取到. 同时, 我还添加了一个回调函数:
$('#grow').animate({ height: 500, width: 500 }, "slow", function(){
alert('The element is done growing!');
});
$('#nav').slideDown('slow');
5. DOM脚本以及事件处理
jQuery最擅长的可能就是操作DOM以及进行事件处理了. 遍历以及操作DOM其实很容易, 绑定移除以及调用事件用起来也很自然顺手,并且和手动写这些代码相比,可以大大的减少错误.
事实上, jQuery简化了DOM的各种操作. 你可以创建一个元素并且使用append()函数把它链接到其他元素上, 可以使用clone()
复制元素, 可以使用html()设置内容,可以使用empty()函数删除内容,使用remove()函数删除元素以及内容, 甚至,可以使用wrap()函数来使用另一个元素包装此元素.
有一些函数,可以靠遍历DOM来改变jQuery对象本身的内容. 又可以得到一个元素的siblings(),parents(), 或者children().你还可以使用next()和prev()来寻找兄弟元素. find()也许是这些函数中最强大的一个了. 它允许你使用一个jQuery选择符来在你的jQuery对象以及其子孙节点中进行搜索.如果配合end()函数,这些函数将变得更加强大. end()函数就像执行撤销一样, 会让你的jQuery对象回退到你调用find()或者parents()
或者其他任一个遍历函数之前的状态.
如果使用上面我们讲到的方法链接,那就可以让很复杂的功能以简介的代码来实现. Listing7展示了一个例子,你将找到一个登录表单,并对其上的元素进行 一些操作.
Listing 7. Traversing and manipulating the DOM with ease:
$('form#login')
// hide all the labels inside the form with the 'optional' class
.find('label.optional').hide().end()
// add a red border to any password fields in the form
.find('input:password').css('border', '1px solid red').end()
// add a submit handler to the form
.submit(function(){
return confirm('Are you sure you want to submit?');
});
处理一般的事件也很简单,就像调用函数click(),submit(),或者 mouseover(),然后传给一个事件监听函数一样. 另外,你还可以使用
bind('eventname', function(){})
unbind('eventname')
unbind()
6. 揭秘jQuery选择符的威力
通常, 你使用ID选择元素, 比如#myid; 或者使用类名来选择,比如 div.myclass. 然而,jQuery有一套相当复杂而且完备的选择符语法,可以让你使用单一的选择符就可以找到任意组合的元素.
jQuery 的选择符语法很大程度上基于CSS3以及XPath. 你对CSS3以及XPath 了解的越多, 你越能更好的使用jQuery.
CSS3包含一些并不是所有浏览器都支持的语法, 所以你有可能不怎么会经常见到它. 但是, 你仍然在jQuery里可以使用它来选择元素, 因为,jQuery有他自己定制的选择符解析引擎. 举例来说, 要给表格中的每一空列增加一个短横线, 则可以使用:empty 伪操作符:
$('td:empty').html('-');
required类名的文本输入框元素.
$('input:not(.required)').hide();
$('ul, ol, dl').hide();
复选框的父元素增加一个边框,可以这样做:
$("input:checkbox/..").css('border', '1px solid #777');
使用不同的类名, 这就是斑马条. 使用jQuery做这个就是小菜一碟,这多亏了:odd为选择符. 下面代码演示使用striped类
改变表格中奇数行的背景色:
$('table.striped > tr:odd').css('background', '#999999');
一个方法使用一个简单的jQuery选择符定位到它.
7. 使用插件扩展jQuey
不像其他的软件那样, 给jQuery写插件绝不是对着一堆复杂的API的一个痛苦的煎熬. 事实上,给jQuery写插件是如此的简单,
以至于你等下都有可能想写个插件来使你的代码更加简练.下面就是你要写的插件最基本的部分:
$.fn.donothing = function(){
return this;
};
函数必须返回this(jQuery对象)来保证不会破坏上面提到的方法链接规则.
你可以很容易的在上面代码基础上扩展. 要写一个改变背景色的插件来代替使用 css('background'),你可以这样:
$.fn.background = function(bg){
return this.css('background', bg);
};
我建议当你发现你在不断的重复代码的时候使用jQuery插件. 比如, 当你使用each()函数来一遍又一遍的处理某个相同的事情的
时候,你可以考虑使用插件[译注:不是很明白.].
由于jQuery的插件十分容易开发,因此已经有成千上万个插件可以供你使用. jQuery 有针对表格,圆角,幻灯效果,提示,日期选择
以及任何你能想到的应用方面的插件.你可以在文后的资源列表中找到完整的插件列表.
最复杂并且使用最广泛的插件是Interface, 一个处理排序,拖动效果,各种复杂特效以及其他有趣的复杂的用户界面效果的动画
插件. Interface对jQuery就像Scriptaculous对Prototype来说一样.
同样流行并且有用的插件是Form插件,允许你简单的使用ajax在后台提交一个表单. 这个插件用在这种情况下:当你需要劫持表单
提交事件,然后找到所有不同的文本输出字段,并使用他们来构建ajax调用.
感谢您的关注……
欢迎转载,转载请注明出处。
作者:修华帅
固定链接:http://www.xiuhuashuai.com/post/502.html
推荐:
相关文章
AJAX编程实践之与服务器通信 2007-10-9 11:21:56AJAX和Web开发新技术:Dynamic Faces 2007-10-9 11:16:20
XmlHttp对象及其方法 2007-1-20 11:12:40
共有1条评论给予了这篇文章
- benben
- 请问可以把实例给我吗?
- 2007-10-26 11:24:14 回复该留言
发表评论
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。