Javascript:当鼠标悬停时,在dom树中获取元素 [英] Javascript: getting element in dom tree when mouseover

查看:151
本文介绍了Javascript:当鼠标悬停时,在dom树中获取元素的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

使用时:

document.onmouseover = function(e) {}

有没有一个属性给我在dom树中的元素?

Is there a property which gives me the element in the dom tree ?

例如我可以设置一个样式为 e.srcElement
但是,如何以后再访问这个元素(例如)重设其样式?
我怎么知道dom树中的哪个地方?
我想要把它放在整个页面转储中。

For example, I can set a style to e.srcElement But, how can I later access this element to (for example) reset its style ? And how can I know at which place in the dom tree it is ? I want to be able to situate it in the whole page dump.

非常感谢。

为了解决稍后重新访问元素的问题,我尝试了这个但是不起作用:

To solve the problem about reaccessing the element later, I tried this but it doesn't work :

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;
};

谢谢

推荐答案

Which HTML element is the target of the event? (on Quirksmode.org, by Peter-Paul Koch). Also have a look at the target attribute of the Event object in W3C DOM Level 2 Event Model.

<!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>

这篇关于Javascript:当鼠标悬停时,在dom树中获取元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆