oim*_*oim 4 html javascript dom mouseover
使用时:
document.onmouseover = function(e) {}
Run Code Online (Sandbox Code Playgroud)
是否有一个属性可以为我提供 dom 树中的元素?
例如,我可以将样式设置为e.srcElement
But,以后如何访问此元素以(例如)重置其样式?我怎么知道它在 dom 树中的哪个位置?我希望能够将它放在整个页面转储中。
非常感谢。
为了解决稍后重新访问元素的问题,我尝试了这个,但它不起作用:
var lastelem;
document.onmouseover = function(e) {
if (lastelem != null){
lastelem.style.border = "0px";
}
if (e===undefined) e= window.event;
var target= 'target' in event? event.target : event.srcElement;
document.getElementById('display').value = target.tagName;
target.style.border = "1px";
lastelem = target;
};
Run Code Online (Sandbox Code Playgroud)
谢谢
哪个 HTML 元素是事件的目标?(在 Quirksmode.org 上,由 Peter-Paul Koch 撰写)。还可以查看W3C DOM Level 2 Event Model 中 Event 对象的target属性。
<!DOCTYPE html>
<html>
<head>
<title>target test</title>
<style>
* { border: 1px solid #fff }
.trigger { background: lightgreen }
</style>
</head>
<body>
<p class="trigger">Trigger testCase().</p>
<p class="trigger">Trigger testCase().</p>
<p class="trigger">Trigger testCase().</p>
<p id="display"></p>
<script>
var lastelem;
document.onmouseover = function (e) {
var event = e || window.event;
if (lastelem) {
lastelem.style.border = "1px solid #fff";
}
var target = event.target || event.srcElement;
document.getElementById('display').innerHTML = target.previousSibling.tagName +
" | " + target.tagName + " | " + (target.nextSibling ? target.nextSibling.tagName : "X");
target.style.border = "1px solid";
lastelem = target;
};
</script>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9165 次 |
| 最近记录: |