0

我需要为整个页面创建一个 shim 来捕获点击事件,但是 shim 不能停止页面上其他 html 元素上的其他事件,例如 mouseover 等。

我有这样的解决方案,但我有几个问题:每当我点击页面时,如果我直接点击一些文本,垫片的点击事件不会触发(没有事件取消在页面上)。

onclick 问题只发生在 IE 中。

在 FF 和 Chrome 中,存在鼠标悬停事件未在后台触发的问题,因此我当然也会感谢任何解决该问题的提示......

这是一个演示问题的非常基本的示例。

有任何想法吗?:-)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
    <style type="text/css">
        body
        {
            font-size:20px;
            height:100%;
        }
        #shim
        {
            position: absolute;
            padding: 0;
            margin: 0;
            top: 0px;
            left: 0px;
            width: 100%;
            height: 100%;
            zindex: 1;
        }
        #trace
        {
            border: 1px solid #ccc;
            height: 100px;
        }
    </style>

    <script type="text/javascript">
        function trace(e) {
            e = e || event;
            document.getElementById('trace').innerHTML = "Hovered innerHTML: " + (e.target || e.srcElement).innerHTML;
        }
    </script>

</head>
<body>
    <div id="shim" onclick="alert('shim clicked')">
    </div>
    <table border="1" onmouseover="trace(event)">
        <tr>
            <td>
                AAAAAA AAAAAA
            </td>
            <td>
                BBBBBB BBBBB
            </td>
            <td>
                CCCCCCCC CCCCC
            </td>
            <td>
                DDDDDD DDDDDDDDDD
            </td>
            <td>
                EEEEEE EEEE
            </td>
            <td>
                FFFFFF FFFFF
            </td>
            <td>
                GGGG GGGGGGGG
            </td>
            <td>
                EEEE EEEE
            </td>
            <td>
                FFFF FFFFFF
            </td>
        </tr>
    </table>
    <div id="trace">
    </div>
</body>
</html>
4

1 回答 1

0

我不知道是否可以解决您的问题,但我在几周前做了一些对我有用的事情。

基本上,我创建了一个全局事件处理程序,在文档元素中注册我需要的所有事件,然后使用 event.srcElement 或 event.element,我能够首先获得触发事件的元素。根据事件和元素,我可以决定要做什么。

于 2010-07-13T17:16:14.527 回答