js+css实现简洁带进度轮播图效果代码

代码语言:html

所属分类:幻灯片

代码描述:js+css实现简洁带进度轮播图效果代码

代码标签: js css 简洁 进度 轮播图

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="en" >

<head>
  <meta charset="UTF-8">
  

  
  
  
  
<style>
* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

body {
  background: #98ede0;
  transition: background 500ms;
  font-family: ui-rounded, "Hiragino Maru Gothic ProN", Quicksand, Comfortaa, Manjari, "Arial Rounded MT", "Arial Rounded MT Bold", Calibri, source-sans-pro, sans-serif;
}

.content {
  margin: 0 auto;
  max-width: 500px;
  height: 100vh;
  height: 100svh;
  min-height: 400px;
  display: flex;
  flex-direction: column;
  padding: 40px 40px 80px;
  justify-content: center;
}

a {
  transition: color 200ms;
  color: rgba(0, 0, 0, 0.5);
  border-radius: 5px;
  text-decoration: none;
  margin: 40px auto 0;
}
a:hover {
  color: black;
  text-decoration: underline;
}
a:focus-visible {
  color: black;
  outline: 3px solid rgba(255, 255, 255, 0.3);
  outline-offset: 5px;
}

.pagination {
  display: flex;
  gap: 10px;
  height: 4px;
  min-height: 4px;
}

.pagination-item {
  border-radius: 100px;
  height: 100%;
  flex: auto;
  background: rgba(0, 0, 0, 0.08);
  overflow: hidden;
  border: 0;
  cursor: pointer;
}

@keyframes progress {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}
.pagination-progress {
  flex: auto;
  background: #333;
  height: 100%;
  width: 0;
}
.pagination-item--running .pagination-progress {
  animation: progress 3s linear forwards;
}
.pagination-item--done .pagination-progress {
  width: 100%;
}
.pagination--paused .pagination-progress {
  animation-play-state: paused;
}
:-moz-window-inactive .pagination-progress {
  animation-play-state: paused;
}

.controls {
  display: flex;
  justify-content: center;
  gap: 12px;
}

.control {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100px;
  border: none;
  outline: none;
  height: 40px;
  flex: 40px 0 0;
  max-width: 100px;
  background: rgba(255, 255, 255, 0.3);
  transition: transform 200ms, background-color 200ms;
  will-change: transform, background-color;
  font-size: 20px;
}
.control:hover {
  cursor: pointer;
  transform: scale(1.15);
  background: rgba(255, 255, 255, 0.45);
}
.control:focus {
  background: rgba(255, 255, 255, 0.6);
}

.icon {
  width: 20px;
}

.icon--play {
  margin-right: -2px;
}

.pagination--paused ~ .controls .icon--pause,
.pagination:not(.pagination--paused) ~ .controls .icon--play {
  display: none;
}

.state {
  font-size: 120px;
  text-align: center;
}
</style>


  
  
</head>

<body >
  <div class="content">

  <div class="pagination">
  </div>

  <div class="state">
    &nbsp;
  </div>

  <div class="controls">
    <button class="control control--prev" aria-label="Previous">
      <svg class="icon" viewBox="0 0 32 32">
        <path d="M20 28a1 1 0 0 1-.521-.146l-18-11a1.002 1.002 0 0 1 0-1.708l18-11A.999.999 0 0 1 21 5v6.11a1 1 0 0 1-.479.854L13.918 16l6.603 4.035c.297.182.479.506.479.854V27a1 1 0 0 1-1 1zM3.918 16 19 25.217V21.45l-7.521-4.596a1 1 0 0 1 0-1.707L19 10.55V6.783L3.918 16z" />
        <path d="M30 28a1 1 0 0 1-.521-.146l-18-11a1.002 1.002 0 0 1 0-1.708l18-11A.999.999 0 0 1 31 5v22a1 1 0 0 1-1 1zM13.918 16 29 25.217V6.783L13.918 16z" />
      </svg>
    </button>
    <button class="control control--play-pause" aria-label="Play/Pause">
      <svg class="icon icon--play" viewBox="0 0 32 32">
        <path d="M7 28a.999.999 0 0 1-1-1V5a1 1 0 0 1 1.521-.854l18 11a1.001 1.001 0 0 1 0 1.708l-18 11A1 1 0 0 1 7 28zM8 6.783v18.434L23.082 16 8 6.783z" />
      </svg>
      <svg class="icon icon--pause" viewBox="0 0 32 32">
        <path d="M13 28H7a1 1 0 0 1-1-1V5a1 1 0 0 1 1-1h6a1 1 0 0 1 1 1v22a1 1 .........完整代码请登录后点击上方下载按钮下载查看

网友评论0