本文主要介绍了CSS中的pointer-events属性的用法,十分的详细,有需要的小伙伴参考下。
绝对定位元素盖住链接或添加某事件handle的元素后,那么该链接的默认行为(页面跳转)或元素事件将不会被触发。mFMHTML5中文学习网 - HTML5先行者学习网
mFMHTML5中文学习网 - HTML5先行者学习网
现在Firefox3.6+/Safari4+/Chrome支持一个称为pointer-events的css属性。使用该属性可以决定是否能穿透绝对定位元素去触发下面元素的某些行为。如下:mFMHTML5中文学习网 - HTML5先行者学习网
mFMHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html>mFMHTML5中文学习网 - HTML5先行者学习网
<html>mFMHTML5中文学习网 - HTML5先行者学习网
<head>mFMHTML5中文学习网 - HTML5先行者学习网
<meta charset="utf-8">mFMHTML5中文学习网 - HTML5先行者学习网
<title>CSS:pointer-events</title>mFMHTML5中文学习网 - HTML5先行者学习网
<style type="text/css">mFMHTML5中文学习网 - HTML5先行者学习网
.overlay1 {mFMHTML5中文学习网 - HTML5先行者学习网
width:80px;mFMHTML5中文学习网 - HTML5先行者学习网
height:20px;mFMHTML5中文学习网 - HTML5先行者学习网
background:gold;mFMHTML5中文学习网 - HTML5先行者学习网
position:absolute;mFMHTML5中文学习网 - HTML5先行者学习网
top:5px;mFMHTML5中文学习网 - HTML5先行者学习网
left:5px;mFMHTML5中文学习网 - HTML5先行者学习网
opacity:0.5;mFMHTML5中文学习网 - HTML5先行者学习网
}mFMHTML5中文学习网 - HTML5先行者学习网
.overlay2 {mFMHTML5中文学习网 - HTML5先行者学习网
width:80px;mFMHTML5中文学习网 - HTML5先行者学习网
height:20px;mFMHTML5中文学习网 - HTML5先行者学习网
background:gold;mFMHTML5中文学习网 - HTML5先行者学习网
position:absolute;mFMHTML5中文学习网 - HTML5先行者学习网
top:40px;mFMHTML5中文学习网 - HTML5先行者学习网
left:5px;mFMHTML5中文学习网 - HTML5先行者学习网
opacity:0.5;mFMHTML5中文学习网 - HTML5先行者学习网
}mFMHTML5中文学习网 - HTML5先行者学习网
.pointer{pointer-events:none;}mFMHTML5中文学习网 - HTML5先行者学习网
</style>mFMHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript">mFMHTML5中文学习网 - HTML5先行者学习网
window.onload = function(){mFMHTML5中文学习网 - HTML5先行者学习网
document.getElementById('chx').onclick = function(){ document.getElementById('a').classNamemFMHTML5中文学习网 - HTML5先行者学习网
= "overlay1 " + ((this.checked)? "pointer" : "");mFMHTML5中文学习网 - HTML5先行者学习网
document.getElementById('b').classNamemFMHTML5中文学习网 - HTML5先行者学习网
= "overlay2 " + ((this.checked)? "pointer" : "");mFMHTML5中文学习网 - HTML5先行者学习网
}mFMHTML5中文学习网 - HTML5先行者学习网
}mFMHTML5中文学习网 - HTML5先行者学习网
</script>mFMHTML5中文学习网 - HTML5先行者学习网
</head>mFMHTML5中文学习网 - HTML5先行者学习网
<body>mFMHTML5中文学习网 - HTML5先行者学习网
<div id="a" class="overlay1"></div>mFMHTML5中文学习网 - HTML5先行者学习网
<div id="b" class="overlay2"></div>mFMHTML5中文学习网 - HTML5先行者学习网
<a href="http://mail.sina.com.cn">SinaMail</a>mFMHTML5中文学习网 - HTML5先行者学习网
<br/><br/>mFMHTML5中文学习网 - HTML5先行者学习网
<span onclick="alert(3);">SinaMail</span>mFMHTML5中文学习网 - HTML5先行者学习网
<p>mFMHTML5中文学习网 - HTML5先行者学习网
<input id="chx" type="checkbox">mFMHTML5中文学习网 - HTML5先行者学习网
<label for="chx">开启穿透点击</label>mFMHTML5中文学习网 - HTML5先行者学习网
</p>mFMHTML5中文学习网 - HTML5先行者学习网
</body>mFMHTML5中文学习网 - HTML5先行者学习网
</html>mFMHTML5中文学习网 - HTML5先行者学习网
mFMHTML5中文学习网 - HTML5先行者学习网默认情况下,链接和span元素被绝对定位的两个div都遮住了。分别点击后无反应,即无法触发链接a的默认行为,无法触发span元素的click事件。但开启穿透点击后支持pointer-events的浏览器Firefox/Safari/Chrome中再次点击链接和span则可以触发相应的行为。mFMHTML5中文学习网 - HTML5先行者学习网
示例非常的清晰易懂,小伙伴们都了解了吧,希望大家能够喜欢。