写一段html,一个div遮罩层默认不显示,内有一个小的div背景为白色,点击遮罩层时遮罩层隐藏,点击里面小div内的元素时候不受影响。
下面是一个简单的HTML示例,包含一个默认不显示的遮罩层(overlay
),以及一个内部的小div
(content
)。点击遮罩层时,遮罩层会隐藏,而点击内部小div
内的元素时不会影响遮罩层的显示状态。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Overlay Example</title>
<style>
body {
font-family: Arial, sans-serif;
}
.overlay {
display: none; /* 默认不显示 */
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.5);
justify-content: center;
align-items: center;
}
.content {
background: white;
padding: 20px;
border-radius: 5px;
}
</style>
</head>
<body>
<button onclick="showOverlay()">Show Overlay</button>
<div class="overlay" id="overlay">
<div class="content" onclick="event.stopPropagation()">
<p>This is the content inside the overlay.</p>
<button>Click me</button>
</div>
</div>
<script>
function showOverlay() {
document.getElementById('overlay').style.display = 'flex';
}
document.getElementById('overlay').addEventListener('click', function() {
this.style.display = 'none';
});
</script>
</body>
</html>
HTML结构:
div
元素作为遮罩层,默认display: none
。div
,背景为白色。CSS样式:
.overlay
类用于遮罩层,默认不显示,使用display: none
。.content
类用于内部的小div
,背景为白色,带有一些填充和圆角。JavaScript:
showOverlay
函数用于显示遮罩层,将其display
属性设置为flex
。div
添加onclick="event.stopPropagation()"
,阻止事件冒泡,确保点击内部元素时不会触发遮罩层的点击事件。这样,当你点击遮罩层时,遮罩层会隐藏,而点击内部小div
内的元素时不会影响遮罩层的显示状态。