for(var i = 0; i < myLinks.length; ++i){
myLinks[i].onclick = function(){
alert(“Hello link: ” + i);
}
}
}
注意,这里我犯了一个错误,我本来以为alert的数目会递增,结果实际运行的结果是每一个alert都是4.
这是因为js没有块级作用域,变量i引用的是for里的那个,循环后变成了4.也即,onclick事件发生的时候才去取i的值,当然都是4了.
下面用jQuery实现这一功能:
$(document).ready(function () {
$(“a”).click(function () {
alert(“Hello link from jQuery!”);
});
});
jQuery中的$()符号会获得页面当中的所有合适的元素.
所以上面的代码隐含了遍历的过程,给每一个元素都加上了事件处理函数.
click方法是jQuery对象提供的方法.
onclick是DOM对象的属性.
DOM里面的很多属性到jQuery里面就变成了方法.
DOM对象和jQuery对象之间的相互转换与区别
看一个例子,首先加一个p标签:
<p id=”clickMe”>Click Me!</p>
先获得一个DOM对象,然后将其转换为一个jQuery对象:
//Part 1: DOM –> jQuery
//DOM object:
var pElement = document.getElementsByTagName(“p”)[0];
alert(“DOM pElement: ” + pElement.innerHTML);
//Convert DOM object to jQuery object:
var pElementjQuery = $(pElement);
alert(“jQuery pElementjQuery: ” + pElementjQuery.html());
也可以先获得一个jQuery对象,再将其转换为DOM对象:
//Part 2: jQuery –> DOM
//jQuery object array:
var clickMejQuery = $(“#clickMe”);
//Convert jQuery object to DOM object (2 ways):
//way 1:
var domClickMe1 = clickMejQuery[0];
alert(“dom1: ” + domClickMe1.innerHTML);
//way 2:
var domClickMe2 = clickMejQuery.get(0);
alert(“dom2: ” + domClickMe2.innerHTML);
再次注意:jQuery中$()获取的是一个满足条件的所有元素的数组.
小总结:
$(“字符串”)会返回满足条件的所有元素的一个数组,其中:
字符串以#开头,表示id;
字符串以.开头,表示CSS的class名;
若非以上两种情况,则改字符串表示标签名.
$(DOM对象)可以得到一个jQuery对象.
希望本文所述对大家的jQuery程序设计有所帮助。










