我一直在研究一个基本的 javascript 下拉菜单,使用 addEventListener 和 attachEvent 来处理单击和鼠标功能。点击事件调用的函数 subOpen 使用 javascript "this" 关键字来获取被点击元素的 id。
添加事件的示例:
//add event listeners to menuitems
for (var i=0; i < menuitems.length; i++) {
if (menuitems[i].addEventListener) {
menuitems[i].addEventListener('click', subOpen, false);
menuitems[i].addEventListener('mouseout', closeTimer, false);
menuitems[i].addEventListener('mouseover', cancelTimer, false);
menuitems[i].addEventListener('selectstart', menucursorselect, false);
} else if (menuitems[i].attachEvent) {
menuitems[i].attachEvent('onclick', subOpen);
menuitems[i].attachEvent('onmouseout', closeTimer);
menuitems[i].attachEvent('onmouseover', cancelTimer);
menuitems[i].attachEvent('onselectstart', menucursorselect);
}
}
使用“this”关键字的 subOpen 函数示例:
function subOpen() {
cancelTimer(); //stops the close timer
if (submenudisplay) {
document.getElementById(submenudisplay).style.display = "none";
activeSubMenu = false;
}
var curMenuId = this.id;
var curSubMenuId = this.id + "submenu";
if (curSubMenuId) {
document.getElementById(curSubMenuId).style.display = "block";
activeSubMenu = true;
}
submenudisplay = curSubMenuId;
现在,除了早期版本的 Internet Explorer 之外,我测试过的所有浏览器都可以正常工作。对于旧版本的 IE,调试器会将“this.id”标记为未定义,因此它不知道要打开哪个子菜单。我做了一些研究,发现旧的 IE 在附加事件时不会复制函数,而是引用它,所以我无法使用“this”关键字捕获任何有用的数据。
我想知道是否有不同的关键字或函数可以用来完成与旧版本 IE 相同的事情。
我的测试代码的完整版本可以在这里找到: