前言:
jQuery是一个不错的javascript产品,我曾经想总结一些javascript的一些常用功能,以备自己调用,然而看了jQuery,发现他做的太强了,不得不向他学习。“永远学习强者”,但是也告诫自己,不要被它们绑住了双手,否则你的创造性就会被扼杀,我建议当工具使用,不必死计其语法,否则自己就“晕”了。我希望有更多有创造性的产品出现。
获取jQuery最新版本:http://jquery.com/src/
一、基本操作:
1、当文档(dom)加载完毕后,立即执行内容:
$(document).ready(function() ...{
// do stuff when DOM is ready
});
2、为所有的A标记添加一个事件。 :)当然也可以是其它的,任意发挥吧。
$("a").click(function() ...{
alert("Hello world!");
});
3、使用选择器与事件
jQuery中提供了两种方法来选择HTML元素,第一种是用CSS和Xpath选择器联合起来形成一个字符串来传送到jQuery的构造器(如:$("div > ul a"));第二种是用jQuery对象的几个methods(方法)。这两种方式还可以联合起来混合使用。
//在一个菜单应用中,将其子菜单中的A标记加样式
$(document).ready(function() ...{
$("#Menu ul a").hover(function()...{
$(this).addClass("blue");
},function()...{
$(this).removeClass("blue");
});
注:id选择加#号前缀,其下级标记用空格隔开。:)是不是很容易啊
hover为其事件,其它事件有click,mouseover,mouseout,change...等。可参考:http://visualjquery.com
4、用这些选择器和事件你已经可以做很多的事情了,但这里有一个更强的好东东!
$(document).ready(function() ...{
$("#orderedlist").find("li").each(function(i) ...{
$(this).html( $(this).html() + " BAM! " + i );
});
});
注:find() 让你在已经选择的element中作条件查找,因此 $("#orderedlist).find("li") 就像 $("#orderedlist li")一样。each()方法迭代了所有的li,并可以在此基础上作更多的处理。 大部分的方法,如addClass(), 都可以用它们自己的 each() 。在这个例子中, html()用来获取每个li的html文本, 追加一些文字,并将之设置为li的html文本。
5、不希望某些特定的元素被选择。jQuery 提供了filter() 和not() 方法来解决这个问题
$(document).ready(function() ...{
$("li").not("[ul]").css("border", "1px solid black");
});
注:这个代码选择了所有的li元素,然后去除了没有ul子元素的li元素。注意体会方便之极的css()方法,并再次提醒请务必实际测试观察效果,比方说换个CSS样式呢?再加一个CSS样式呢?像这样:$("li").not("[ul]").css("border", "1px solid black").css("color","red")。
6、可以在子元素和属性(elements and attributes)上用作过滤器,比如你可能想选择所有的带有name属性的链接:
$(document).ready(function() ...{
$("a[@name]").background("#eee");
});
注:这个代码给所有带有name属性的链接加了一个背景色。
6.1常见的情况是以name来选择链接,你可能需要选择一个有特点href属性的链接,这在不同的浏览器下对href的理解可能会不一致,所以我们的部分匹配("*=")的方式来代替完全匹配("="):
$(document).ready(function() ...{
$("a[@href*=/content/gallery]").click(function() ...{
// do something with all links that point somewhere to /content/gallery
});
});
小示例,比如一个FAQ的页面,答案首先会隐藏,当问题点击时,答案显示出来,jQuery代码如下:
$(document).ready(function() ...{
$('#faq').find('dd').hide().end().find('dt').click(function() ...{
var answer = $(this).next();
if (answer.is(':visible')) ...{
answer.slideUp();
} else ...{
answer.slideDown();
}
});
});
注:在点击事件中的,我们用 $(this).next() 来找到dt下面紧接的一个dd元素,这让我们可以快速地选择在被点击问题下面的答案。
7、除了选择同级别的元素外,你也可以选择父级的元素。可能你想在用户鼠标移到文章某段的某个链接时,它的父级元素--也就是文章的这一段突出显示,试试这个:
$(document).ready(function() ...{
$("a").hover(function() ...{
$(this).parents("p").addClass("highlight");
}, function() ...{
$(this).parents("p").removeClass("highlight");
});
});
8、在我们继续之前我们先来看看这一步: jQuery会让代码变得更短从而更容易理解和维护,下面是
$(document).ready(callback)的缩写法:
$(function() ...{
// code to execute when the DOM is ready
});
应用到我们的Hello world例子中,可以这样:
$(function() ...{
$("a").click(function() ...{
alert("Hello world!");
});
});
:)是不是很容易呀,多亏了jQuery团队的努力呀!