首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >DOM onmouseover未出现

DOM onmouseover未出现
EN

Stack Overflow用户
提问于 2011-10-26 20:46:41
回答 3查看 1.1K关注 0票数 0

当在我的表中创建新的行时,我试图插入一个onmouseover,但是它没有出现。我错过了什么愚蠢的东西吗?

代码语言:javascript
复制
    var row = document.createElement("TR");
    row.id = i;
    row.onmouseover = hover(i);
    var td1 = document.createElement("TD");
    row.appendChild(td1);
    tbody.appendChild(row);

变量'i‘是循环中的当前数字。行的ID显示正常,但onmouseover显示不正常。

EN

Stack Overflow用户

回答已采纳

发布于 2011-10-26 20:49:20

使用匿名函数为i的值创建闭包,并确保将函数设置为onmouseover,而不是调用函数的结果:

代码语言:javascript
复制
var row = document.createElement("TR");
(function (i) {
    row.onmouseover = function () { hover(i) };
})(row.id);
var td1 = document.createElement("TD");
row.appendChild(td1);
tbody.appendChild(row);

仔细查看您的代码,就会发现您实际上并没有设置TR元素的id属性。但是,您可能希望完全避免这种情况,并在悬停函数中使用this上下文:

代码语言:javascript
复制
var row = document.createElement("TR");
row.onmouseover = hover;
var td1 = document.createElement("TD");
row.appendChild(td1);
tbody.appendChild(row);
代码语言:javascript
复制
function hover() { 
    alert(this.rowIndex);  // <-- `this` refers to the row element
}
票数 3
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7902768

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档