
要实现类似Calendly网站的左右分割布局,其中左侧内容可滚动,右侧图片保持粘性并根据滚动内容切换,我们需要结合使用CSS的Flexbox布局和position: sticky属性。
首先,我们需要一个包含左右两部分的容器。左侧用于放置可滚动的内容,右侧则放置粘性的图片或动态内容。
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>粘性侧边栏分割布局</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="page-wrapper">
<!-- 左侧可滚动内容区域 -->
<div class="scrollable-content">
<p data-image="image1.jpg">这里是第一段内容,当滚动到这里时,右侧图片会切换到第一张。</p>
<p data-image="image2.jpg">这是第二段内容,滚动到这里时,右侧图片会切换到第二张。</p>
<p data-image="image3.jpg">这是第三段内容,滚动到这里时,右侧图片会切换到第三张。</p>
<p data-image="image4.jpg">这是第四段内容,滚动到这里时,右侧图片会切换到第四张。</p>
<!-- 可以添加更多内容段落 -->
</div>
<!-- 右侧粘性侧边栏 -->
<div class="sticky-sidebar">
<div class="sticky-image-container">
<!-- 初始图片或占位符,通过JS动态切换 -->
<img src="placeholder.jpg" alt="动态图片" class="active-image">
</div>
</div>
</div>
<script src="script.js"></script>
</body>
</html>在上述HTML结构中:
接下来,我们为上述HTML结构添加样式,实现左右分割和粘性效果。
/* style.css */
body {
margin: 0;
font-family: sans-serif;
line-height: 1.6;
color: #333;
}
.page-wrapper {
display: flex; /* 启用Flexbox布局 */
min-height: 100vh; /* 确保容器至少占据整个视口高度 */
overflow: hidden; /* 防止子元素溢出 */
}
.scrollable-content {
flex: 1; /* 占据一半宽度 */
width: 50%; /* 明确指定宽度,与flex:1配合确保50% */
background-color: #f0f2f5; /* 左侧背景色 */
padding: 40px;
box-sizing: border-box; /* 包含padding在内的宽度计算 */
}
.scrollable-content p {
height: 50vh; /* 每个段落占据视口高度的50%,确保有足够的滚动空间 */
margin-bottom: 40px; /* 段落间距 */
display: flex; /* 用于垂直居中内容 */
align-items: center; /* 垂直居中 */
justify-content: center; /* 水平居中 */
font-size: 1.2em以上就是创建带有粘性侧边栏和滚动驱动内容切换的分割布局教程的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号