神奇的css属性pointer-events

绝对定位元素盖住链接或添加某事件 handle 的元素后,那么该链接的默认行为(页面跳转)或元素事件将不会被触发。
现在 Firefox3.6+/Safari4+/Chrome 支持一个称为 pointer-events 的 css 属性。使用该属性可以决定是否能穿透绝对定位元素去触发下面元素的某些行为。如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>CSS:pointer-events</title>
<style type="text/css">
    .overlay1 {
        width:80px;
        height:20px;
        background:gold;
        position:absolute;
        top:5px;
        left:5px;
        opacity:0.5;
    }
    .overlay2 {
        width:80px;
        height:20px;
        background:gold;
        position:absolute;
        top:40px;
        left:5px;
        opacity:0.5;
    }
    .pointer{pointer-events:none;}
</style>
<script type="text/javascript">
window.onload = function(){
    document.getElementById('chx').onclick = function(){
        document.getElementById('a').className
            = "overlay1 " + ((this.checked)? "pointer" : "");
        document.getElementById('b').className
            = "overlay2 " + ((this.checked)? "pointer" : "");
    }
}
</script>
</head>
<body>
    <div id="a" class="overlay1"></div>
    <div id="b" class="overlay2"></div>
    <a href="http://mail.sina.com.cn">SinaMail</a>
    <br/><br/>
    <span onclick="alert(3);">SinaMail</span>
    <p>
        <input id="chx" type="checkbox">
        <label for="chx">开启穿透点击</label>
    </p>
</body>
</html>

  

  

默认情况下,链接和 span 元素被绝对定位的两个 div 都遮住了。分别点击后无反应,即无法触发链接 a 的默认行为,无法触发 span 元素的 click 事件。但开启穿透点击后支持 pointer-events 的浏览器 Firefox/Safari/Chrome 中再次点击链接和 span 则可以触发相应的行为。

如果你正使用 Firefox/Safari/Chrome 浏览本博客,可以点击下面试试

 
 
SinaMail
SinaMail


开启穿透点击