jQuery库为Web脚本编程提供了通用(跨浏览器)的抽象层,使得它几乎适用于任何脚本编程的情形。jQuery通常能为我们提供以下功能:
如果使用纯JavaScript的方式来遍历DOM以及查找DOM的某个部分编写很多冗余的代码,而使用jQuery只需要一行代码就足够了。例如,找到所有应用了.content class样式的div中所有的P标签,只需要下面的一行代码:
1 $('div.content').find('p');
使用jQuery我们可以动态的修改页面的CSS即使在页面呈现以后。jQuery仍然能够改变文档中某个部分的类或者个别的样式属性。例如,找到页面所有的ul标签的第一个li子标签,然后为它们增加名为active的样式,代码如下:
1 $('ul > li:first').addClass('active');
使用jQuery我们可以很容易地对页面DOM进行修改,例如,为ID为"container"的元素添加一个链接:
1 $('#container').append('<a href="more.html">more</a>');
jQuery提供了截获形形色色的页面事件(比如用户单击某个链接)的适当方式,而不需要使用事件处理程序拆散HTML代码。此外,它的事件处理API也消除了经常困扰Web开发人员浏览器的不一致性。
1 $('button.show-details').click(function() { 2 $('div.details').show(); 3 });
上面的代码表示:为使用的.show-details样式的button元素添加一个click事件,事件就是:显示使用.details样式的DIV。
jQuery中内置的一批淡入、擦除之类的效果,以及制作新效果的工具包,为此提供了便利。
1 $(function () { 2 $("#btnShow").click(function () { 3 $("#msubject").hide("slow"); 4 }); 5 });
jQuery统一了多种浏览器的Ajax操作,使得开发人员更多的专注服务器端开发。
1 function (data, type) { 2 // 对Ajax返回的原始数据进行预处理 3 return data // 返回处理后的数据 4 }
除了这些完全针对文档的特性之外,jQuery也改进了对基本的JavaScript数据结构(例如迭代和数组操作等)。
1 $.each(obj, function(key, value) { 2 total += value; 3 });