仅使用CSS制作轮播

这篇文章发布于

DeathGhost 编辑, 归类于css » 当前评论0条。

在不使用JavaScript或其他库的情况下,如何使用HTML布局和CSS属性制作轮播图,精心制作,实际运用中也未尝不可!

上次文章提到关于“CSS Scroll Snapping滚动吸附锁定元素或位置”,今天借此属性在不使用JavaScript或相关库的情况下实现图片轮播效果。

CSS轮播图
仅CSS轮播图

首先通过HTML与CSS实现基础布局设计,设计结构,左侧缩略导航图,右侧展示其完整视觉图片。

这里同样借助上篇文章提到的“CSS Grid 二维网格结构布局”方法。

HTML结构

侧边栏缩略图,主体部分为视觉主图区域。

<main class="wrap">
  <aside>
    <ul>
      <li>
        <a href="#one">
	  <img src="001.jpg">
	</a>
      </li>
      <li>
       <a href="#two">
	 <img src="002.jpg">
       </a>
      </li>
      <li>
	<a href="#three">
	  <img src="003.jpg">
	</a>
      </li>
      <li>
        <a href="#four">
	  <img src="004.jpg">
	</a>
      </li>
      <li>
	<a href="#five">
	  <img src="005.jpg">
	</a>
      </li>
    </ul>
  </aside>
  <section>
    <img id="one" src="001.jpg">
    <img id="two" src="002.jpg">
    <img id="three" src="003.jpg">
    <img id="four" src="004.jpg">
    <img id="five" src="005.jpg">
  </section>
</main>

CSS设置

通过CSS Grid布局以及CSS Scroll Snapping属性设置。

.wrap{
	background:rgb(37, 36, 36);
	width:640px;
	height:354px;
	display: grid;
	grid-template-columns: 1fr 5fr;
}
.wrap img{
	width: auto;
	max-width: 100%;
	height: auto;
}
.wrap section{
	height: 100%;
	overflow: auto;
	scroll-snap-type: y mandatory;
}
.wrap section img{
	object-fit: cover;
	height: 100%;
	scroll-snap-align: start;
}

需要注意的是布局grid-template-columns: 1fr 5fr;图片滚动包裹scroll-snap-type: y mandatory;以及图片展示object-fit: cover的设置。

效果

最后我们可以将其图片滚动变得平滑一点,我们在视觉图区域包裹设置scroll-behavior: smooth即可。


CSS 轮播图 css轮播图 焦点图 banner轮播图