您的位置:首页 > Web前端 > JavaScript

Javascript利用闭包循环绑定事件

2009-11-19 22:17 716 查看
我们先看一个关于Javascript利用循环绑定事件的例子:

例如:一个不确定长度的列表,在鼠标经过某一条的时候改变背景。

[align=center][/align]

[align=left]﹤!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"﹥
﹤html xmlns="http://www.w3.org/1999/xhtml" ﹥
﹤head﹥
﹤title﹥Untitled Page﹤/title﹥
﹤/head﹥
﹤body﹥
﹤ul id="list"﹥
﹤li﹥第1条记录﹤/li﹥
﹤li﹥第2条记录﹤/li﹥
﹤li﹥第3条记录﹤/li﹥
﹤li﹥第4条记录﹤/li﹥
﹤li﹥第5条记录﹤/li﹥
﹤li﹥第6条记录﹤/li﹥
﹤/ul﹥
﹤script type="text/javascript"﹥
var list_obj = document.getElementById("list").getElementsByTagName("li"); //获取list下面的所有li的对象数组
for (var i = 0; i ﹤= list_obj.length; i++) {
list_obj[i].onmousemove = function() {
this.style.backgroundColor = "#cdcdcd";
}
list_obj[i].onmouseout = function() {
this.style.backgroundColor = "#FFFFFF";
}
}
﹤/script﹥
﹤/body﹥
﹤/html﹥[/align]
这个例子循环为一组对象绑定事件处理函数。

但是,如果我们在这个基础上增加一些需求。比如在点击某一条记录的时候弹出这是第几条记录?

可能你会理所当然的这么写:

[align=center][/align]

﹤!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"﹥
﹤html xmlns="http://www.w3.org/1999/xhtml" ﹥
﹤head﹥
﹤title﹥Untitled Page﹤/title﹥
﹤/head﹥
﹤body﹥
﹤ul id="list"﹥
﹤li﹥第1条记录﹤/li﹥
﹤li﹥第2条记录﹤/li﹥
﹤li﹥第3条记录﹤/li﹥
﹤li﹥第4条记录﹤/li﹥
﹤li﹥第5条记录﹤/li﹥
﹤li﹥第6条记录﹤/li﹥
﹤/ul﹥
﹤script type="text/javascript"﹥
function tt(nob) {
this.clickFunc = function() {
alert("这是第" + (nob + 1) + "记录");
}
}
var list_obj = document.getElementById("list").getElementsByTagName("li"); //获取list下面的所有li的对象数组
for (var i = 0; i ﹤= list_obj.length; i++) {
list_obj[i].onmousemove = function() {
this.style.backgroundColor = "#cdcdcd";
}
list_obj[i].onmouseout = function() {
this.style.backgroundColor = "#FFFFFF";
}
var col = new tt(i);
list_obj[i].onclick = col.clickFunc;
}
﹤/script﹥
﹤/body﹥
﹤/html﹥
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: