它可以使用多個漸變背景和指針事件來完成。這裏有一個demo和一個截圖。由於pointer-events
CSS屬性,可以選擇通知文本。我的演示版現在只適用於Firefox,但可以輕鬆移植到支持multiplegradient背景和pointer-events
的其他瀏覽器。但是,pointer-events
屬性會影響整個疊加層,而不僅僅是可能不合需要的洞。
。
而這裏的代碼:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<style type="text/css">
body {
margin: 0;
padding: 0;
}
.underneath {
padding: 0;
margin: 265px 0 0 0;
width: 600px;
}
.overlay {
top: 0;
left: 0;
position: absolute;
width: 600px;
height: 600px;
background: -moz-linear-gradient(90deg, rgba(0,0,0,1) 150px, transparent 150px, transparent),
-moz-linear-gradient(0deg, rgba(0,0,0,1) 150px, transparent 150px, transparent),
-moz-linear-gradient(-90deg, rgba(0,0,0,1) 150px, transparent 150px, transparent),
-moz-linear-gradient(180deg, rgba(0,0,0,1) 150px, transparent 150px, transparent);
pointer-events: none; /* send mouse events beneath this layer */
}
</style>
</head>
<body>
<p class="underneath">
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore
eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt
in culpa qui officia deserunt mollit anim id est laborum.
</p>
<div class="overlay"></div>
</body>
</html>
甚則有純色和內容你嘗試過使用邊框(和邊框圖片)?並有「窗口」部分是真正的透明背景 – Raynos
內容是文字和表格元素,我不能僞造他們,我不認爲。 – Toby
@Toby,你有沒有找到一個解決方案,通過這樣的一個div層「打孔」? – BenRacicot