css+js实现横向图文列表卡片可拖动滚动控制效果代码
代码语言:html
所属分类:拖放
代码描述:css+js实现横向图文列表卡片可拖动滚动控制效果代码
代码标签: css js 横向 图文 列表 卡片 拖动 滚动 控制
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter&display=swap" rel="stylesheet">
<style>
:root {
--accent: rgb(212, 255, 0);
--accent-hover: rgb(190, 228, 0);
--accent-active: #72d534;
--control: #49aa00;
--secondary: #ECEFEB;
--secondary-hover: #E0E4DE;
--secondary-active: #6c6c6b;
--headline-color: rgba(100, 105, 150, 1);
--event-text: rgba(29, 32, 59, 1);
--success: rgba(80, 189, 85, 1);
--error: rgba(232, 113, 113, 1);
--white: rgba(255, 255, 255, 1);
--accent-text: #163300;
}
body {
padding: 16px;
display: flex;
height: 100vh;
min-width: 320px;
font-family: "Inter", sans-serif;
}
* {
box-sizing: border-box;
}
.top-bar {
display: flex;
gap: 16px;
align-items: center;
width: 100%;
flex-direction: row;
color: var(--headline-color);
}
.top-bar h2 {
font-size: 1.2rem;
font-weight: 700;
line-height: 1.5rem;
}
.top-bar svg {
color: var(--headline-color);
}
.action-buttons {
position: relative;
display: inline-flex;
flex: 0 0 auto;
gap: 0.5rem;
scroll-snap-align: start;
width: 100%;
flex-wrap: wrap;
}
.action-button {
color: var(--accent-text);
border-radius: 1rem;
height: 2rem;
gap: 0.25rem;
cursor: pointer;
display: flex;
padding: 0 0.75rem;
font-weight: 600;
transition: all 0.2s ease-in-out;
white-space: nowrap;
align-items: center;
text-decoration: none;
background: var(--secondary);
}
.action-button--primary:active {
background: var(--accent-active);
}
.action-button:active {
background: var(--secondary-active);
}
.action-button--horizontal-scroll {
border-radius: 50%;
cursor: pointer;
border: none;
outline: none;
width: 2rem;
height: 2rem;
background: var(--accent);
}
.action-button--horizontal-scroll:hover {
background: var(--accent-hover);
}
.action-button--horizontal-scroll:active {
background: var(--accent-active);
}
.action-button--horizontal-scroll:disabled {
cursor: not-allowed;
background: var(--secondary);
}
.action-button--horizontal-scroll:disabled:hover {
background: var(--secondary);
}
.action-button--horizontal-scroll:disabled:active {
background: var(--secondary);
}
#action-button--previous {
margin-left: auto;
transform: rotate(-90deg);
}
#action-button--next {
transform: rotate(90deg);
}
.action-button:hover {
background: var(--secondary-hover);
}
.action-button--primary {
background: var(--accent);
}
.action-button--primary:hover {
background: var(--accent-hover);
}
.action-button--primary:active {
background: var(--accent-active);
}
#events {
display: flex;
gap: 1.5rem;
padding: 1rem 0px;
width: 100%;
flex-direction: row;
overflow: auto;
}
.event {
appearance: none;
text-decoration: none;
position: relative;
transition: all 0.2s ease-in-out;
min-width: 20rem;
cursor: pointer;
flex-direction: column;
justify-content: space-between;
scroll-snap-align: start;
overflow: hidden;
color: rgba(29, 32, 59, 1);
}
.event__image {
position: relative;
}
.event__indicator {
position: absolute;
padding: 0.5rem;
min-width: 3.5rem;
min-height: 3.5rem;
display: flex;
flex-direction: column;
justify-content: center;
background: var(--white);
align-items: center;
border-radius: 0.5rem;
}
.event__date {
top: 0.5rem;
left: 0.5rem;
font-size: 1.35rem;
}
.event__date__month {
font-size: 0.6rem;
text-transform: uppercase;
font-weight: bold;
color: var(--event-headline);
}
.event__type {
top: 0.5rem;
right: 0.5rem;
}
.event__type svg {
color: var(--event-text);
height: 2rem;
width: 2rem;
}
.event-description {
color: var(--event-text);
padding: 0.5rem 0.75rem;
}
.event img {
width: 100%;
height: 15rem;
border-radius: 1rem;
object-fit: cover;
object-position: top;
}
.event h2 {
font-size: 1.375rem;
letter-spacing: normal;
overflow-wrap: normal;
white-space: nowrap;
font-weight: 700;
line-height: 1.25rem;
color: var(--event-headline);
overflow: hidden;
text-overflow: ellipsis;
}
.bottom-stats {
display: flex;
justify-content: space-between;
gap: 1rem;
width: 100%;
flex-direction: row;
color: var(--headline-color);
}
.bottom-stat {
display: flex;
gap: 0.5rem;
align-items: center;
flex-direction: row;
}
.container {
max-width: 50rem;
width: 100%;
min-width: 18rem;
margin: 7.5rem auto;
}
.circle {
height: 0.5rem;
width: 0.5rem;
border-radius: 50%;
}
.circle--green {
background: var(--success);
}
.circle--red {
background: var(--error);
}
</style>
</head>
<body>
<div class="container">
<div class="top-bar">
<svg aria-hidden="true" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"
stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round">
<path stroke="none" d="M0 0h24v24H0z" fill="none" />
<path d="M4 7a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12z" />
<path d="M16 3v4" />
<path d="M8 3v4" />
<path d="M4 11h16" />
<path d="M7 14h.013" />
<path d="M10.01 14h.005" />
<path d="M13.01 14h.005" />
.........完整代码请登录后点击上方下载按钮下载查看
网友评论0