react实现一个自适应图文轮播图效果代码
代码语言:html
所属分类:幻灯片
代码描述:react实现一个自适应图文轮播图效果代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en" > <head> <meta charset="UTF-8"> <link type="text/css" rel="stylesheet" href="//repo.bfw.wiki/bfwrepo/css/reset.min.css"> <meta name="viewport" content="width=device-width, initial-scale=1"> <style> @import url("https://fonts.googleapis.com/css?family=Playfair+Display:700|IBM+Plex+Sans:500&display=swap"); :root { --color-primary: #6B7A8F; --color-secondary: #101118; --color-accent: #1D1F2F; --color-focus: #6D64F7; --base-duration: 600ms; --base-ease: cubic-bezier(0.25, 0.46, 0.45, 0.84); } *, *:before, *:after { box-sizing: border-box; } html, body { height: 100%; } body { font-family: "IBM Plex Sans", sans-serif; background-color: var(--color-secondary); } #app { align-items: center; display: flex; height: 100%; justify-content: center; overflow-x: hidden; width: 100%; } h1, h2, h3 { font-family: "Playfair Display", serif; } .visuallyhidden { clip: rect(1px, 1px, 1px, 1px); height: 1px; overflow: hidden; position: absolute !important; white-space: nowrap; width: 1px; } .icon { fill: var(--color-primary); width: 100%; } .btn { background-color: var(--color-primary); border: none; border-radius: 0.125rem; color: white; cursor: pointer; font-family: inherit; font-size: inherit; padding: 1rem 2.5rem 1.125rem; } .btn:focus { outline-color: var(--color-focus); outline-offset: 2px; outline-style: solid; outline-width: 3px; } .btn:active { transform: translateY(1px); } .slider__controls { display: flex; justify-content: center; position: absolute; top: calc(100% + 1rem); width: 100%; } .slider__controls .btn { --size: 3rem; align-items: center; background-color: transparent; border: 3px solid transparent; border-radius: 100%; display: flex; height: var(--size); padding: 0; width: var(--size); } .slider__controls .btn:focus { border-color: var(--color-focus); outline: none; } .slider__controls .btn--previous > * { transform: rotate(180deg); } .slider { --slide-size: 70vmin; --slide-margin: 4vmin; height: var(--slide-size); margin: 0 auto; position: relative; width: var(--slide-size); } .slider__wrapper { display: flex; margin: 0 calc(var(--slide-margin) * -1); position: absolute; transition: transform var(--base-duration) cubic-bezier(0.25, 1, 0.35, 1); } .slide { align-items: center; color: white; display: flex; flex: 1; flex-direction: column; height: var(--slide-size); justify-content: center; margin: 0 var(--slide-margin); opacity: 0.25; position: relative; text-align: center; transition: opacity calc(var(--base-duration) / 2) var(--base-ease), transform calc(var(--base-duration) / 2) var(--base-ease); width: var(--slide-size); z-index: 1; } .slide--previous:hover, .slide--next:hover { opacity: 0.5; } .slide--previous { cursor: w-resize; } .slide--previous:hover { transform: translateX(2%); } .slide--next { cursor: e-resize; } .slide--next:hover { transform: translateX(-2%); } .slide--current { --x: 0; --y: 0; --d: 50; opacity: 1; pointer-events: auto; -webkit-user-select: auto; -moz-user-select: auto; -ms-user-select: auto; user-select: auto; } @media (hover: hover) { .slide--current:hover .slide__image-wrapper { transform: scale(1.025) translate(calc(var(--x) / var(--d) * 1px), calc(var(--y) / var(--d) * 1px)); } } .slide__image-wrapper { background-color: var(--color-accent); border-radius: 1%; height: 100%; left: 0%; overflow: hidden; position: absolute; top: 0%; transition: transform calc(var(--base-duration) / 4) var(--base-ease); width: 100%; } .slide__image { --d: 20; height: 1.........完整代码请登录后点击上方下载按钮下载查看
网友评论0